From 215f423cbe18fe9ca14a26caef918d303bad28ff Mon Sep 17 00:00:00 2001 From: Jacek Antonelli Date: Fri, 15 Aug 2008 23:45:11 -0500 Subject: Second Life viewer sources 1.18.4.0-RC --- linden/doc/contributions.txt | 88 +- linden/etc/message.xml | 10 +- linden/indra/SConstruct | 51 +- linden/indra/indra_complete/indra_complete.sln | 73 +- linden/indra/lib/python/indra/__init__.py | 33 +- linden/indra/lib/python/indra/base/__init__.py | 27 + linden/indra/lib/python/indra/base/config.py | 74 + linden/indra/lib/python/indra/base/llsd.py | 870 ++++ linden/indra/lib/python/indra/base/lluuid.py | 290 ++ linden/indra/lib/python/indra/ipc/__init__.py | 40 +- linden/indra/lib/python/indra/ipc/compatibility.py | 40 +- linden/indra/lib/python/indra/ipc/httputil.py | 9 + linden/indra/lib/python/indra/ipc/llmessage.py | 40 +- linden/indra/lib/python/indra/ipc/llsdhttp.py | 84 + linden/indra/lib/python/indra/ipc/mysql_pool.py | 103 + linden/indra/lib/python/indra/ipc/russ.py | 157 + linden/indra/lib/python/indra/ipc/saranwrap.py | 637 +++ .../indra/lib/python/indra/ipc/servicebuilder.py | 93 + linden/indra/lib/python/indra/ipc/tokenstream.py | 40 +- linden/indra/lib/python/indra/ipc/webdav.py | 597 +++ linden/indra/lib/python/indra/ipc/xml_rpc.py | 273 ++ linden/indra/lib/python/indra/util/__init__.py | 40 +- .../indra/lib/python/indra/util/helpformatter.py | 52 + linden/indra/lib/python/indra/util/llmanifest.py | 40 +- linden/indra/lib/python/indra/util/llversion.py | 95 + linden/indra/lib/python/indra/util/named_query.py | 215 + .../linux_crash_logger/linux_crash_logger.cpp | 6 +- linden/indra/llaudio/audioengine.cpp | 14 +- linden/indra/llaudio/audioengine.h | 3 + linden/indra/llaudio/audioengine_fmod.cpp | 8 +- linden/indra/llaudio/audioengine_fmod.h | 3 + linden/indra/llaudio/listener.cpp | 3 + linden/indra/llaudio/listener.h | 5 +- linden/indra/llaudio/listener_ds3d.h | 3 + linden/indra/llaudio/listener_fmod.cpp | 3 + linden/indra/llaudio/listener_fmod.h | 3 + linden/indra/llaudio/listener_openal.h | 3 + linden/indra/llaudio/llaudiodecodemgr.cpp | 8 +- linden/indra/llaudio/llaudiodecodemgr.h | 3 + linden/indra/llaudio/vorbisdecode.cpp | 7 +- linden/indra/llaudio/vorbisdecode.h | 3 + linden/indra/llaudio/vorbisencode.cpp | 7 +- linden/indra/llaudio/vorbisencode.h | 3 + linden/indra/llcharacter/llanimationstates.cpp | 5 +- linden/indra/llcharacter/llanimationstates.h | 3 + linden/indra/llcharacter/llbvhloader.cpp | 11 +- linden/indra/llcharacter/llbvhloader.h | 8 +- linden/indra/llcharacter/llcharacter.cpp | 3 + linden/indra/llcharacter/llcharacter.h | 3 + linden/indra/llcharacter/lleditingmotion.cpp | 3 + linden/indra/llcharacter/lleditingmotion.h | 3 + linden/indra/llcharacter/llgesture.cpp | 3 + linden/indra/llcharacter/llgesture.h | 3 + linden/indra/llcharacter/llhandmotion.cpp | 3 + linden/indra/llcharacter/llhandmotion.h | 3 + linden/indra/llcharacter/llheadrotmotion.cpp | 3 + linden/indra/llcharacter/llheadrotmotion.h | 3 + linden/indra/llcharacter/lljoint.cpp | 3 + linden/indra/llcharacter/lljoint.h | 3 + linden/indra/llcharacter/lljointsolverrp3.cpp | 5 +- linden/indra/llcharacter/lljointsolverrp3.h | 3 + linden/indra/llcharacter/lljointstate.h | 3 + linden/indra/llcharacter/llkeyframefallmotion.cpp | 3 + linden/indra/llcharacter/llkeyframefallmotion.h | 3 + linden/indra/llcharacter/llkeyframemotion.cpp | 3 + linden/indra/llcharacter/llkeyframemotion.h | 3 + linden/indra/llcharacter/llkeyframemotionparam.cpp | 3 + linden/indra/llcharacter/llkeyframemotionparam.h | 3 + linden/indra/llcharacter/llkeyframestandmotion.cpp | 3 + linden/indra/llcharacter/llkeyframestandmotion.h | 3 + linden/indra/llcharacter/llkeyframewalkmotion.cpp | 3 + linden/indra/llcharacter/llkeyframewalkmotion.h | 3 + linden/indra/llcharacter/llmotion.cpp | 3 + linden/indra/llcharacter/llmotion.h | 3 + linden/indra/llcharacter/llmotioncontroller.cpp | 7 + linden/indra/llcharacter/llmotioncontroller.h | 3 + linden/indra/llcharacter/llmultigesture.cpp | 3 + linden/indra/llcharacter/llmultigesture.h | 3 + linden/indra/llcharacter/llpose.cpp | 3 + linden/indra/llcharacter/llpose.h | 3 + linden/indra/llcharacter/llstatemachine.cpp | 3 + linden/indra/llcharacter/llstatemachine.h | 3 + linden/indra/llcharacter/lltargetingmotion.cpp | 3 + linden/indra/llcharacter/lltargetingmotion.h | 3 + linden/indra/llcharacter/llvisualparam.cpp | 3 + linden/indra/llcharacter/llvisualparam.h | 9 +- linden/indra/llcommon/bitpack.h | 3 + linden/indra/llcommon/ctype_workaround.h | 5 +- linden/indra/llcommon/doublelinkedlist.h | 3 + linden/indra/llcommon/files.lst | 1 + linden/indra/llcommon/imageids.h | 3 + linden/indra/llcommon/indra_constants.h | 3 + linden/indra/llcommon/linden_common.h | 37 +- linden/indra/llcommon/linked_lists.h | 3 + linden/indra/llcommon/llagentconstants.h | 3 + linden/indra/llcommon/llapp.cpp | 3 + linden/indra/llcommon/llapp.h | 3 + linden/indra/llcommon/llapr.cpp | 5 +- linden/indra/llcommon/llapr.h | 4 + linden/indra/llcommon/llares.cpp | 776 ++++ linden/indra/llcommon/llares.h | 572 +++ linden/indra/llcommon/llassettype.cpp | 5 +- linden/indra/llcommon/llassettype.h | 3 + linden/indra/llcommon/llassoclist.h | 3 + linden/indra/llcommon/llavatarconstants.h | 3 + linden/indra/llcommon/llbase32.cpp | 5 +- linden/indra/llcommon/llbase32.h | 5 +- linden/indra/llcommon/llbase64.cpp | 5 +- linden/indra/llcommon/llbase64.h | 5 +- linden/indra/llcommon/llboost.h | 3 + linden/indra/llcommon/llchat.h | 3 + linden/indra/llcommon/llclickaction.h | 3 + linden/indra/llcommon/llcommon.cpp | 3 + linden/indra/llcommon/llcommon.h | 3 + linden/indra/llcommon/llcommon.vcproj | 3 + linden/indra/llcommon/llcommon_vc8.vcproj | 8 + linden/indra/llcommon/llcriticaldamp.cpp | 4 +- linden/indra/llcommon/llcriticaldamp.h | 3 + linden/indra/llcommon/lldarray.h | 3 + linden/indra/llcommon/lldarrayptr.h | 3 + linden/indra/llcommon/lldate.cpp | 7 +- linden/indra/llcommon/lldate.h | 3 + linden/indra/llcommon/lldefs.h | 3 + linden/indra/llcommon/lldepthstack.h | 3 + linden/indra/llcommon/lldlinked.h | 5 +- linden/indra/llcommon/lldqueueptr.h | 3 + linden/indra/llcommon/llendianswizzle.h | 3 + linden/indra/llcommon/llenum.h | 3 + linden/indra/llcommon/llerror.cpp | 31 +- linden/indra/llcommon/llerror.h | 3 + linden/indra/llcommon/llerrorcontrol.h | 5 +- linden/indra/llcommon/llerrorlegacy.h | 5 +- linden/indra/llcommon/llerrorthread.cpp | 3 + linden/indra/llcommon/llerrorthread.h | 3 + linden/indra/llcommon/llevent.cpp | 3 + linden/indra/llcommon/llevent.h | 3 + linden/indra/llcommon/lleventemitter.h | 3 + linden/indra/llcommon/llextendedstatus.h | 5 +- linden/indra/llcommon/llfasttimer.cpp | 14 +- linden/indra/llcommon/llfasttimer.h | 5 +- linden/indra/llcommon/llfile.cpp | 3 + linden/indra/llcommon/llfile.h | 10 +- linden/indra/llcommon/llfixedbuffer.cpp | 3 + linden/indra/llcommon/llfixedbuffer.h | 3 + linden/indra/llcommon/llformat.cpp | 7 +- linden/indra/llcommon/llformat.h | 7 +- linden/indra/llcommon/llframetimer.cpp | 3 + linden/indra/llcommon/llframetimer.h | 3 + linden/indra/llcommon/llhash.h | 3 + linden/indra/llcommon/llindexedqueue.h | 3 + linden/indra/llcommon/lllinkedqueue.h | 3 + linden/indra/llcommon/llliveappconfig.cpp | 3 + linden/indra/llcommon/llliveappconfig.h | 3 + linden/indra/llcommon/lllivefile.cpp | 3 + linden/indra/llcommon/lllivefile.h | 3 + linden/indra/llcommon/lllocalidhashmap.h | 3 + linden/indra/llcommon/lllslconstants.h | 3 + linden/indra/llcommon/llmap.h | 7 +- linden/indra/llcommon/llmemory.cpp | 146 + linden/indra/llcommon/llmemory.h | 8 +- linden/indra/llcommon/llmemorystream.cpp | 3 + linden/indra/llcommon/llmemorystream.h | 3 + linden/indra/llcommon/llmemtype.h | 3 + linden/indra/llcommon/llmetrics.cpp | 5 +- linden/indra/llcommon/llmetrics.h | 5 +- linden/indra/llcommon/llmortician.cpp | 3 + linden/indra/llcommon/llmortician.h | 3 + linden/indra/llcommon/llnametable.h | 3 + linden/indra/llcommon/llpreprocessor.h | 3 + linden/indra/llcommon/llpriqueuemap.h | 3 + linden/indra/llcommon/llprocessor.cpp | 7 +- linden/indra/llcommon/llprocessor.h | 3 + linden/indra/llcommon/llptrskiplist.h | 3 + linden/indra/llcommon/llptrskipmap.h | 3 + linden/indra/llcommon/llqueuedthread.cpp | 3 + linden/indra/llcommon/llqueuedthread.h | 3 + linden/indra/llcommon/llrun.cpp | 3 + linden/indra/llcommon/llrun.h | 3 + linden/indra/llcommon/llsd.cpp | 6 +- linden/indra/llcommon/llsd.h | 3 + linden/indra/llcommon/llsdserialize.cpp | 3 + linden/indra/llcommon/llsdserialize.h | 3 + linden/indra/llcommon/llsdserialize_xml.cpp | 3 + linden/indra/llcommon/llsdserialize_xml.h | 3 + linden/indra/llcommon/llsdutil.cpp | 3 + linden/indra/llcommon/llsdutil.h | 3 + linden/indra/llcommon/llsecondlifeurls.cpp | 3 + linden/indra/llcommon/llsecondlifeurls.h | 3 + linden/indra/llcommon/llsimplehash.h | 3 + linden/indra/llcommon/llskiplist.h | 3 + linden/indra/llcommon/llskipmap.h | 3 + linden/indra/llcommon/llstack.h | 3 + linden/indra/llcommon/llstat.cpp | 3 + linden/indra/llcommon/llstat.h | 3 + linden/indra/llcommon/llstatenums.h | 3 + linden/indra/llcommon/llstl.h | 9 +- linden/indra/llcommon/llstreamtools.cpp | 3 + linden/indra/llcommon/llstreamtools.h | 3 + linden/indra/llcommon/llstrider.h | 3 + linden/indra/llcommon/llstring.cpp | 23 + linden/indra/llcommon/llstring.h | 90 +- linden/indra/llcommon/llstringtable.cpp | 3 + linden/indra/llcommon/llstringtable.h | 3 + linden/indra/llcommon/llsys.cpp | 5 + linden/indra/llcommon/llsys.h | 3 + linden/indra/llcommon/llthread.cpp | 5 +- linden/indra/llcommon/llthread.h | 3 + linden/indra/llcommon/lltimer.cpp | 6 +- linden/indra/llcommon/lltimer.h | 8 +- linden/indra/llcommon/lluri.cpp | 3 + linden/indra/llcommon/lluri.h | 3 + linden/indra/llcommon/lluuidhashmap.h | 3 + linden/indra/llcommon/llversionserver.h | 5 +- linden/indra/llcommon/llversionviewer.h | 7 +- linden/indra/llcommon/llworkerthread.cpp | 3 + linden/indra/llcommon/llworkerthread.h | 3 + linden/indra/llcommon/metaclass.cpp | 3 + linden/indra/llcommon/metaclass.h | 3 + linden/indra/llcommon/metaclasst.h | 3 + linden/indra/llcommon/metaproperty.cpp | 3 + linden/indra/llcommon/metaproperty.h | 3 + linden/indra/llcommon/metapropertyt.h | 3 + linden/indra/llcommon/processor.h | 3 + linden/indra/llcommon/reflective.cpp | 3 + linden/indra/llcommon/reflective.h | 3 + linden/indra/llcommon/reflectivet.h | 3 + linden/indra/llcommon/roles_constants.h | 3 + linden/indra/llcommon/stdenums.h | 3 + linden/indra/llcommon/stdtypes.h | 6 +- linden/indra/llcommon/string_table.h | 3 + linden/indra/llcommon/timer.h | 3 + linden/indra/llcommon/timing.cpp | 3 + linden/indra/llcommon/timing.h | 6 +- linden/indra/llcommon/u64.cpp | 3 + linden/indra/llcommon/u64.h | 3 + linden/indra/llimage/llimage.cpp | 11 +- linden/indra/llimage/llimage.h | 6 +- linden/indra/llimage/llimagebmp.cpp | 3 + linden/indra/llimage/llimagebmp.h | 3 + linden/indra/llimage/llimagedxt.cpp | 3 + linden/indra/llimage/llimagedxt.h | 3 + linden/indra/llimage/llimagej2c.cpp | 44 +- linden/indra/llimage/llimagej2c.h | 4 + linden/indra/llimage/llimagejpeg.cpp | 3 + linden/indra/llimage/llimagejpeg.h | 3 + linden/indra/llimage/llimagepng.cpp | 6 +- linden/indra/llimage/llimagepng.h | 6 +- linden/indra/llimage/llimagetga.cpp | 50 + linden/indra/llimage/llimagetga.h | 3 + linden/indra/llimage/llimageworker.cpp | 8 +- linden/indra/llimage/llimageworker.h | 3 + linden/indra/llimage/llmapimagetype.h | 3 + linden/indra/llimage/llpngwrapper.cpp | 6 +- linden/indra/llimage/llpngwrapper.h | 6 +- linden/indra/llimagej2coj/llimagej2coj.cpp | 10 +- linden/indra/llimagej2coj/llimagej2coj.h | 3 + linden/indra/llinventory/llcategory.cpp | 3 + linden/indra/llinventory/llcategory.h | 3 + linden/indra/llinventory/lleconomy.cpp | 3 + linden/indra/llinventory/lleconomy.h | 3 + linden/indra/llinventory/llinventory.cpp | 5 +- linden/indra/llinventory/llinventory.h | 3 + linden/indra/llinventory/llinventorytype.cpp | 3 + linden/indra/llinventory/llinventorytype.h | 3 + linden/indra/llinventory/lllandmark.cpp | 6 +- linden/indra/llinventory/lllandmark.h | 3 + linden/indra/llinventory/llnotecard.cpp | 3 + linden/indra/llinventory/llnotecard.h | 3 + linden/indra/llinventory/llparcel.cpp | 46 +- linden/indra/llinventory/llparcel.h | 33 +- linden/indra/llinventory/llparcelflags.h | 3 + linden/indra/llinventory/llpermissions.cpp | 9 + linden/indra/llinventory/llpermissions.h | 7 +- linden/indra/llinventory/llpermissionsflags.h | 3 + linden/indra/llinventory/llsaleinfo.cpp | 3 + linden/indra/llinventory/llsaleinfo.h | 6 +- linden/indra/llinventory/lltransactionflags.cpp | 87 + linden/indra/llinventory/lltransactionflags.h | 21 + linden/indra/llinventory/lltransactiontypes.h | 3 + linden/indra/llinventory/lluserrelations.cpp | 3 + linden/indra/llinventory/lluserrelations.h | 3 + linden/indra/llmath/camera.h | 3 + linden/indra/llmath/coordframe.h | 3 + linden/indra/llmath/llbboxlocal.cpp | 3 + linden/indra/llmath/llbboxlocal.h | 3 + linden/indra/llmath/llcamera.cpp | 3 + linden/indra/llmath/llcamera.h | 3 + linden/indra/llmath/llcoord.h | 3 + linden/indra/llmath/llcoordframe.cpp | 84 +- linden/indra/llmath/llcoordframe.h | 3 + linden/indra/llmath/llcrc.cpp | 5 +- linden/indra/llmath/llcrc.h | 3 + linden/indra/llmath/llinterp.h | 3 + linden/indra/llmath/llmath.h | 9 +- linden/indra/llmath/llmd5.cpp | 8 +- linden/indra/llmath/llmd5.h | 6 +- linden/indra/llmath/lloctree.h | 3 + linden/indra/llmath/llperlin.cpp | 3 + linden/indra/llmath/llperlin.h | 3 + linden/indra/llmath/llplane.h | 3 + linden/indra/llmath/llquantize.h | 28 + linden/indra/llmath/llquaternion.cpp | 23 +- linden/indra/llmath/llquaternion.h | 3 + linden/indra/llmath/llrand.cpp | 5 +- linden/indra/llmath/llrand.h | 3 + linden/indra/llmath/llrect.cpp | 3 + linden/indra/llmath/llrect.h | 3 + linden/indra/llmath/lltreenode.h | 3 + linden/indra/llmath/lluuid.cpp | 9 +- linden/indra/llmath/lluuid.h | 3 + linden/indra/llmath/llv4math.h | 5 +- linden/indra/llmath/llv4matrix3.h | 5 +- linden/indra/llmath/llv4matrix4.h | 5 +- linden/indra/llmath/llv4vector3.h | 5 +- linden/indra/llmath/llvolume.cpp | 74 +- linden/indra/llmath/llvolume.h | 3 + linden/indra/llmath/llvolumemgr.cpp | 3 + linden/indra/llmath/llvolumemgr.h | 3 + linden/indra/llmath/m3math.cpp | 3 + linden/indra/llmath/m3math.h | 3 + linden/indra/llmath/m4math.cpp | 3 + linden/indra/llmath/m4math.h | 3 + linden/indra/llmath/raytrace.cpp | 3 + linden/indra/llmath/raytrace.h | 3 + linden/indra/llmath/v2math.cpp | 3 + linden/indra/llmath/v2math.h | 5 +- linden/indra/llmath/v3color.cpp | 3 + linden/indra/llmath/v3color.h | 3 + linden/indra/llmath/v3dmath.cpp | 3 + linden/indra/llmath/v3dmath.h | 3 + linden/indra/llmath/v3math.cpp | 3 + linden/indra/llmath/v3math.h | 3 + linden/indra/llmath/v4color.cpp | 3 + linden/indra/llmath/v4color.h | 3 + linden/indra/llmath/v4coloru.cpp | 3 + linden/indra/llmath/v4coloru.h | 3 + linden/indra/llmath/v4math.cpp | 3 + linden/indra/llmath/v4math.h | 3 + linden/indra/llmath/xform.cpp | 3 + linden/indra/llmath/xform.h | 57 +- linden/indra/llmedia/llmediabase.cpp | 3 + linden/indra/llmedia/llmediabase.h | 3 + linden/indra/llmedia/llmediaemitter.h | 3 + linden/indra/llmedia/llmediaemitterevents.h | 3 + linden/indra/llmedia/llmediaengine.cpp | 3 + linden/indra/llmedia/llmediaengine.h | 3 + linden/indra/llmedia/llmediaimplgstreamer.cpp | 5 +- linden/indra/llmedia/llmediaimplgstreamer.h | 5 +- linden/indra/llmedia/llmediaimplgstreamer_syms.cpp | 5 +- linden/indra/llmedia/llmediaimplgstreamer_syms.h | 5 +- .../indra/llmedia/llmediaimplgstreamervidplug.cpp | 7 +- linden/indra/llmedia/llmediaimplgstreamervidplug.h | 5 +- linden/indra/llmedia/llmediaimplquicktime.cpp | 3 + linden/indra/llmedia/llmediaimplquicktime.h | 3 + linden/indra/llmedia/llmediamoviebase.cpp | 3 + linden/indra/llmedia/llmediamoviebase.h | 3 + linden/indra/llmedia/llmediaobservers.h | 3 + linden/indra/llmessage/llassetstorage.cpp | 6 +- linden/indra/llmessage/llassetstorage.h | 3 + linden/indra/llmessage/llblowfishcipher.cpp | 5 +- linden/indra/llmessage/llblowfishcipher.h | 5 +- linden/indra/llmessage/llbuffer.cpp | 3 + linden/indra/llmessage/llbuffer.h | 3 + linden/indra/llmessage/llbufferstream.cpp | 3 + linden/indra/llmessage/llbufferstream.h | 3 + linden/indra/llmessage/llcachename.cpp | 12 +- linden/indra/llmessage/llcachename.h | 6 +- linden/indra/llmessage/llcallbacklisth.h | 3 + linden/indra/llmessage/llchainio.cpp | 3 + linden/indra/llmessage/llchainio.h | 3 + linden/indra/llmessage/llcipher.h | 3 + linden/indra/llmessage/llcircuit.cpp | 3 + linden/indra/llmessage/llcircuit.h | 3 + linden/indra/llmessage/llclassifiedflags.cpp | 3 + linden/indra/llmessage/llclassifiedflags.h | 3 + linden/indra/llmessage/llcurl.cpp | 3 + linden/indra/llmessage/llcurl.h | 3 + linden/indra/llmessage/lldatapacker.cpp | 5 +- linden/indra/llmessage/lldatapacker.h | 8 +- linden/indra/llmessage/lldbstrings.h | 3 + linden/indra/llmessage/lldispatcher.cpp | 3 + linden/indra/llmessage/lldispatcher.h | 3 + linden/indra/llmessage/lleventflags.h | 3 + linden/indra/llmessage/llfiltersd2xmlrpc.cpp | 3 + linden/indra/llmessage/llfiltersd2xmlrpc.h | 3 + linden/indra/llmessage/llfollowcamparams.h | 3 + linden/indra/llmessage/llhost.cpp | 3 + linden/indra/llmessage/llhost.h | 3 + linden/indra/llmessage/llhttpassetstorage.cpp | 42 +- linden/indra/llmessage/llhttpassetstorage.h | 3 + linden/indra/llmessage/llhttpclient.cpp | 7 +- linden/indra/llmessage/llhttpclient.h | 11 + linden/indra/llmessage/llhttpnode.cpp | 3 + linden/indra/llmessage/llhttpnode.h | 3 + linden/indra/llmessage/llhttpsender.cpp | 5 +- linden/indra/llmessage/llhttpsender.h | 5 +- linden/indra/llmessage/llinstantmessage.cpp | 3 + linden/indra/llmessage/llinstantmessage.h | 3 + linden/indra/llmessage/llinvite.h | 3 + linden/indra/llmessage/lliobuffer.cpp | 3 + linden/indra/llmessage/lliobuffer.h | 3 + linden/indra/llmessage/lliohttpserver.cpp | 3 + linden/indra/llmessage/lliohttpserver.h | 3 + linden/indra/llmessage/lliopipe.cpp | 3 + linden/indra/llmessage/lliopipe.h | 3 + linden/indra/llmessage/lliosocket.cpp | 3 + linden/indra/llmessage/lliosocket.h | 3 + linden/indra/llmessage/llioutil.cpp | 3 + linden/indra/llmessage/llioutil.h | 3 + linden/indra/llmessage/llloginflags.h | 3 + linden/indra/llmessage/lllogtextmessage.cpp | 3 + linden/indra/llmessage/lllogtextmessage.h | 3 + linden/indra/llmessage/llmail.cpp | 3 + linden/indra/llmessage/llmail.h | 3 + linden/indra/llmessage/llmessagebuilder.cpp | 3 + linden/indra/llmessage/llmessagebuilder.h | 5 +- linden/indra/llmessage/llmessageconfig.cpp | 12 +- linden/indra/llmessage/llmessageconfig.h | 3 + linden/indra/llmessage/llmessagereader.cpp | 5 +- linden/indra/llmessage/llmessagereader.h | 5 +- linden/indra/llmessage/llmessagetemplate.cpp | 5 +- linden/indra/llmessage/llmessagetemplate.h | 5 +- linden/indra/llmessage/llmessagetemplateparser.cpp | 5 +- linden/indra/llmessage/llmessagetemplateparser.h | 3 + linden/indra/llmessage/llmessagethrottle.cpp | 3 + linden/indra/llmessage/llmessagethrottle.h | 3 + linden/indra/llmessage/llmime.cpp | 3 + linden/indra/llmessage/llmime.h | 3 + linden/indra/llmessage/llmsgvariabletype.h | 5 +- linden/indra/llmessage/llnamevalue.cpp | 3 + linden/indra/llmessage/llnamevalue.h | 7 +- linden/indra/llmessage/llnullcipher.cpp | 3 + linden/indra/llmessage/llnullcipher.h | 3 + linden/indra/llmessage/llpacketack.cpp | 5 +- linden/indra/llmessage/llpacketack.h | 3 + linden/indra/llmessage/llpacketbuffer.cpp | 3 + linden/indra/llmessage/llpacketbuffer.h | 3 + linden/indra/llmessage/llpacketring.cpp | 3 + linden/indra/llmessage/llpacketring.h | 3 + linden/indra/llmessage/llpartdata.cpp | 3 + linden/indra/llmessage/llpartdata.h | 5 +- linden/indra/llmessage/llpumpio.cpp | 8 +- linden/indra/llmessage/llpumpio.h | 3 + linden/indra/llmessage/llqueryflags.h | 3 + linden/indra/llmessage/llregionflags.h | 6 + linden/indra/llmessage/llregionhandle.h | 5 +- linden/indra/llmessage/llsdappservices.cpp | 3 + linden/indra/llmessage/llsdappservices.h | 3 + linden/indra/llmessage/llsdhttpserver.cpp | 3 + linden/indra/llmessage/llsdhttpserver.h | 3 + linden/indra/llmessage/llsdmessagebuilder.cpp | 5 +- linden/indra/llmessage/llsdmessagebuilder.h | 5 +- linden/indra/llmessage/llsdmessagereader.cpp | 5 +- linden/indra/llmessage/llsdmessagereader.h | 31 + linden/indra/llmessage/llsdrpcclient.cpp | 3 + linden/indra/llmessage/llsdrpcclient.h | 3 + linden/indra/llmessage/llsdrpcserver.cpp | 3 + linden/indra/llmessage/llsdrpcserver.h | 3 + linden/indra/llmessage/llservice.cpp | 3 + linden/indra/llmessage/llservice.h | 3 + linden/indra/llmessage/llservicebuilder.cpp | 62 +- linden/indra/llmessage/llservicebuilder.h | 45 +- linden/indra/llmessage/lltaskname.h | 3 + linden/indra/llmessage/llteleportflags.h | 3 + .../indra/llmessage/lltemplatemessagebuilder.cpp | 5 +- linden/indra/llmessage/lltemplatemessagebuilder.h | 5 +- linden/indra/llmessage/lltemplatemessagereader.cpp | 5 +- linden/indra/llmessage/lltemplatemessagereader.h | 5 +- linden/indra/llmessage/llthrottle.cpp | 3 + linden/indra/llmessage/llthrottle.h | 3 + linden/indra/llmessage/lltransfermanager.cpp | 3 + linden/indra/llmessage/lltransfermanager.h | 3 + linden/indra/llmessage/lltransfersourceasset.cpp | 3 + linden/indra/llmessage/lltransfersourceasset.h | 3 + linden/indra/llmessage/lltransfersourcefile.cpp | 3 + linden/indra/llmessage/lltransfersourcefile.h | 5 +- linden/indra/llmessage/lltransfertargetfile.cpp | 3 + linden/indra/llmessage/lltransfertargetfile.h | 7 +- linden/indra/llmessage/lltransfertargetvfile.cpp | 3 + linden/indra/llmessage/lltransfertargetvfile.h | 3 + linden/indra/llmessage/llurlrequest.cpp | 3 + linden/indra/llmessage/llurlrequest.h | 3 + linden/indra/llmessage/lluseroperation.cpp | 3 + linden/indra/llmessage/lluseroperation.h | 3 + linden/indra/llmessage/llvehicleparams.h | 3 + linden/indra/llmessage/llxfer.cpp | 3 + linden/indra/llmessage/llxfer.h | 3 + linden/indra/llmessage/llxfer_file.cpp | 3 + linden/indra/llmessage/llxfer_file.h | 5 +- linden/indra/llmessage/llxfer_mem.cpp | 3 + linden/indra/llmessage/llxfer_mem.h | 5 +- linden/indra/llmessage/llxfer_vfile.cpp | 3 + linden/indra/llmessage/llxfer_vfile.h | 5 +- linden/indra/llmessage/llxfermanager.cpp | 3 + linden/indra/llmessage/llxfermanager.h | 3 + linden/indra/llmessage/llxorcipher.cpp | 3 + linden/indra/llmessage/llxorcipher.h | 3 + linden/indra/llmessage/machine.h | 3 + linden/indra/llmessage/mean_collision_data.h | 5 +- linden/indra/llmessage/message.cpp | 27 +- linden/indra/llmessage/message.h | 5 +- linden/indra/llmessage/message_prehash.cpp | 3 + linden/indra/llmessage/message_prehash.h | 3 + linden/indra/llmessage/message_string_table.cpp | 3 + linden/indra/llmessage/net.cpp | 4 +- linden/indra/llmessage/net.h | 3 + linden/indra/llmessage/network.cpp | 3 + linden/indra/llmessage/network.h | 3 + linden/indra/llmessage/partsyspacket.cpp | 3 + linden/indra/llmessage/partsyspacket.h | 3 + linden/indra/llmessage/patch_code.cpp | 3 + linden/indra/llmessage/patch_code.h | 3 + linden/indra/llmessage/patch_dct.cpp | 3 + linden/indra/llmessage/patch_dct.h | 3 + linden/indra/llmessage/patch_idct.cpp | 3 + linden/indra/llmessage/sound_ids.h | 3 + linden/indra/llprimitive/legacy_object_types.h | 3 + linden/indra/llprimitive/llmaterialtable.cpp | 3 + linden/indra/llprimitive/llmaterialtable.h | 3 + linden/indra/llprimitive/llprimitive.cpp | 50 + linden/indra/llprimitive/llprimitive.h | 6 +- linden/indra/llprimitive/lltextureanim.cpp | 3 + linden/indra/llprimitive/lltextureanim.h | 3 + linden/indra/llprimitive/lltextureentry.cpp | 3 + linden/indra/llprimitive/lltextureentry.h | 7 + linden/indra/llprimitive/lltree_common.h | 3 + linden/indra/llprimitive/lltreeparams.cpp | 3 + linden/indra/llprimitive/lltreeparams.h | 3 + linden/indra/llprimitive/llvolumemessage.cpp | 3 + linden/indra/llprimitive/llvolumemessage.h | 3 + linden/indra/llprimitive/llvolumexml.cpp | 3 + linden/indra/llprimitive/llvolumexml.h | 3 + linden/indra/llprimitive/material_codes.h | 3 + linden/indra/llprimitive/object_flags.h | 6 +- linden/indra/llrender/llfont.cpp | 3 + linden/indra/llrender/llfont.h | 3 + linden/indra/llrender/llfontgl.cpp | 3 + linden/indra/llrender/llfontgl.h | 3 + linden/indra/llrender/llgldbg.cpp | 3 + linden/indra/llrender/llgldbg.h | 3 + linden/indra/llrender/llimagegl.cpp | 3 + linden/indra/llrender/llimagegl.h | 3 + linden/indra/llrender/llvertexbuffer.cpp | 3 + linden/indra/llrender/llvertexbuffer.h | 3 + linden/indra/llrender/llvertexprogramgl.cpp | 3 + linden/indra/llrender/llvertexprogramgl.h | 3 + linden/indra/llui/llalertdialog.cpp | 94 +- linden/indra/llui/llalertdialog.h | 5 +- linden/indra/llui/llbutton.cpp | 15 +- linden/indra/llui/llbutton.h | 29 +- linden/indra/llui/llcallbackmap.h | 3 + linden/indra/llui/llcheckboxctrl.cpp | 7 +- linden/indra/llui/llcheckboxctrl.h | 7 +- linden/indra/llui/llclipboard.cpp | 3 + linden/indra/llui/llclipboard.h | 3 + linden/indra/llui/llcombobox.cpp | 21 +- linden/indra/llui/llcombobox.h | 9 +- linden/indra/llui/llctrlselectioninterface.cpp | 3 + linden/indra/llui/llctrlselectioninterface.h | 3 + linden/indra/llui/lldraghandle.cpp | 3 + linden/indra/llui/lldraghandle.h | 3 + linden/indra/llui/lleditmenuhandler.cpp | 43 +- linden/indra/llui/lleditmenuhandler.h | 43 +- linden/indra/llui/llfloater.cpp | 3 + linden/indra/llui/llfloater.h | 3 + linden/indra/llui/llfocusmgr.cpp | 3 + linden/indra/llui/llfocusmgr.h | 3 + linden/indra/llui/llhtmlhelp.h | 3 + linden/indra/llui/lliconctrl.cpp | 3 + linden/indra/llui/lliconctrl.h | 3 + linden/indra/llui/llkeywords.cpp | 3 + linden/indra/llui/llkeywords.h | 3 + linden/indra/llui/lllineeditor.cpp | 50 +- linden/indra/llui/lllineeditor.h | 19 +- linden/indra/llui/llmemberlistener.h | 5 +- linden/indra/llui/llmenugl.cpp | 15 +- linden/indra/llui/llmenugl.h | 9 +- linden/indra/llui/llmodaldialog.cpp | 3 + linden/indra/llui/llmodaldialog.h | 3 + linden/indra/llui/llpanel.cpp | 13 +- linden/indra/llui/llpanel.h | 11 +- linden/indra/llui/llradiogroup.cpp | 3 + linden/indra/llui/llradiogroup.h | 3 + linden/indra/llui/llresizebar.cpp | 3 + linden/indra/llui/llresizebar.h | 3 + linden/indra/llui/llresizehandle.cpp | 3 + linden/indra/llui/llresizehandle.h | 3 + linden/indra/llui/llresmgr.cpp | 3 + linden/indra/llui/llresmgr.h | 3 + linden/indra/llui/llrootview.cpp | 3 + linden/indra/llui/llrootview.h | 3 + linden/indra/llui/llscrollbar.cpp | 3 + linden/indra/llui/llscrollbar.h | 3 + linden/indra/llui/llscrollcontainer.cpp | 3 + linden/indra/llui/llscrollcontainer.h | 3 + linden/indra/llui/llscrollingpanellist.cpp | 3 + linden/indra/llui/llscrollingpanellist.h | 3 + linden/indra/llui/llscrolllistctrl.cpp | 46 +- linden/indra/llui/llscrolllistctrl.h | 13 +- linden/indra/llui/llslider.cpp | 3 + linden/indra/llui/llslider.h | 3 + linden/indra/llui/llsliderctrl.cpp | 9 +- linden/indra/llui/llsliderctrl.h | 7 +- linden/indra/llui/llspinctrl.cpp | 5 +- linden/indra/llui/llspinctrl.h | 5 +- linden/indra/llui/llstyle.cpp | 3 + linden/indra/llui/llstyle.h | 3 + linden/indra/llui/lltabcontainer.cpp | 3 + linden/indra/llui/lltabcontainer.h | 3 + linden/indra/llui/lltabcontainervertical.cpp | 3 + linden/indra/llui/lltabcontainervertical.h | 3 + linden/indra/llui/lltextbox.cpp | 9 +- linden/indra/llui/lltextbox.h | 9 +- linden/indra/llui/lltexteditor.cpp | 25 +- linden/indra/llui/lltexteditor.h | 17 +- linden/indra/llui/llui.cpp | 3 + linden/indra/llui/llui.h | 3 + linden/indra/llui/lluiconstants.h | 3 + linden/indra/llui/lluictrl.cpp | 7 +- linden/indra/llui/lluictrl.h | 7 +- linden/indra/llui/lluictrlfactory.cpp | 6 +- linden/indra/llui/lluictrlfactory.h | 3 + linden/indra/llui/lluistring.cpp | 3 + linden/indra/llui/lluistring.h | 3 + linden/indra/llui/lluixmltags.h | 177 +- linden/indra/llui/llundo.cpp | 3 + linden/indra/llui/llundo.h | 3 + linden/indra/llui/llview.cpp | 26 +- linden/indra/llui/llview.h | 27 +- linden/indra/llui/llviewborder.cpp | 3 + linden/indra/llui/llviewborder.h | 3 + linden/indra/llui/llviewquery.cpp | 3 + linden/indra/llui/llviewquery.h | 3 + linden/indra/llvfs/lldir.cpp | 4 + linden/indra/llvfs/lldir.h | 3 + linden/indra/llvfs/lldir_linux.cpp | 3 + linden/indra/llvfs/lldir_linux.h | 4 +- linden/indra/llvfs/lldir_mac.cpp | 3 + linden/indra/llvfs/lldir_mac.h | 4 +- linden/indra/llvfs/lldir_solaris.cpp | 3 + linden/indra/llvfs/lldir_solaris.h | 4 +- linden/indra/llvfs/lldir_win32.cpp | 3 + linden/indra/llvfs/lldir_win32.h | 3 + linden/indra/llvfs/lllfsthread.cpp | 3 + linden/indra/llvfs/lllfsthread.h | 3 + linden/indra/llvfs/llvfile.cpp | 3 + linden/indra/llvfs/llvfile.h | 3 + linden/indra/llvfs/llvfs.cpp | 5 +- linden/indra/llvfs/llvfs.h | 5 +- linden/indra/llvfs/llvfsthread.cpp | 3 + linden/indra/llvfs/llvfsthread.h | 3 + linden/indra/llwindow/lldxhardware.cpp | 4 +- linden/indra/llwindow/lldxhardware.h | 3 + linden/indra/llwindow/llgl.cpp | 3 + linden/indra/llwindow/llgl.h | 3 + linden/indra/llwindow/llglheaders.h | 3 + linden/indra/llwindow/llglstates.h | 3 + linden/indra/llwindow/llglstubs.h | 3 + linden/indra/llwindow/llgltypes.h | 3 + linden/indra/llwindow/llkeyboard.cpp | 3 + linden/indra/llwindow/llkeyboard.h | 3 + linden/indra/llwindow/llkeyboardmacosx.cpp | 3 + linden/indra/llwindow/llkeyboardmacosx.h | 3 + linden/indra/llwindow/llkeyboardsdl.cpp | 3 + linden/indra/llwindow/llkeyboardsdl.h | 3 + linden/indra/llwindow/llkeyboardwin32.cpp | 3 + linden/indra/llwindow/llkeyboardwin32.h | 3 + linden/indra/llwindow/llmousehandler.h | 3 + linden/indra/llwindow/llwindow.cpp | 3 + linden/indra/llwindow/llwindow.h | 5 +- linden/indra/llwindow/llwindowheadless.cpp | 3 + linden/indra/llwindow/llwindowheadless.h | 3 + linden/indra/llwindow/llwindowlinux.cpp | 3 + linden/indra/llwindow/llwindowlinux.h | 3 + linden/indra/llwindow/llwindowmacosx-objc.h | 3 + linden/indra/llwindow/llwindowmacosx-objc.mm | 3 + linden/indra/llwindow/llwindowmacosx.cpp | 3 + linden/indra/llwindow/llwindowmacosx.h | 3 + linden/indra/llwindow/llwindowmesaheadless.cpp | 3 + linden/indra/llwindow/llwindowmesaheadless.h | 3 + linden/indra/llwindow/llwindowsdl.cpp | 38 +- linden/indra/llwindow/llwindowsdl.h | 3 + linden/indra/llwindow/llwindowsolaris.cpp | 3 + linden/indra/llwindow/llwindowsolaris.h | 3 + linden/indra/llwindow/llwindowwin32.cpp | 197 +- linden/indra/llwindow/llwindowwin32.h | 7 +- linden/indra/llxml/llcontrol.cpp | 3 + linden/indra/llxml/llcontrol.h | 3 + linden/indra/llxml/llxmlnode.cpp | 3 + linden/indra/llxml/llxmlnode.h | 7 +- linden/indra/llxml/llxmlparser.cpp | 3 + linden/indra/llxml/llxmlparser.h | 3 + linden/indra/llxml/llxmltree.cpp | 3 + linden/indra/llxml/llxmltree.h | 3 + linden/indra/lscript/lscript_alloc.h | 6 +- linden/indra/lscript/lscript_byteconvert.h | 44 + linden/indra/lscript/lscript_byteformat.h | 3 + linden/indra/lscript/lscript_compile/indra.l | 8 +- linden/indra/lscript/lscript_compile/indra.y | 5 +- .../lscript/lscript_compile/lscript_alloc.cpp | 3 + .../lscript/lscript_compile/lscript_bytecode.cpp | 3 + .../lscript/lscript_compile/lscript_bytecode.h | 3 + .../lscript/lscript_compile/lscript_error.cpp | 3 + .../indra/lscript/lscript_compile/lscript_error.h | 6 +- .../indra/lscript/lscript_compile/lscript_heap.cpp | 3 + .../indra/lscript/lscript_compile/lscript_heap.h | 3 + .../lscript/lscript_compile/lscript_resource.cpp | 3 + .../lscript/lscript_compile/lscript_resource.h | 5 +- .../lscript/lscript_compile/lscript_scope.cpp | 3 + .../indra/lscript/lscript_compile/lscript_scope.h | 3 + .../indra/lscript/lscript_compile/lscript_tree.cpp | 3 + .../indra/lscript/lscript_compile/lscript_tree.h | 5 +- .../lscript/lscript_compile/lscript_typecheck.cpp | 3 + .../lscript/lscript_compile/lscript_typecheck.h | 3 + linden/indra/lscript/lscript_execute.h | 8 +- .../lscript/lscript_execute/lscript_execute.cpp | 163 +- .../lscript_execute/lscript_heapruntime.cpp | 3 + .../lscript/lscript_execute/lscript_heapruntime.h | 3 + .../lscript/lscript_execute/lscript_readlso.cpp | 3 + .../lscript/lscript_execute/lscript_readlso.h | 3 + linden/indra/lscript/lscript_export.h | 3 + linden/indra/lscript/lscript_http.h | 3 + linden/indra/lscript/lscript_library.h | 4 +- .../lscript/lscript_library/lscript_alloc.cpp | 5 +- .../lscript/lscript_library/lscript_export.cpp | 3 + .../lscript/lscript_library/lscript_library.cpp | 3 + linden/indra/lscript/lscript_rt_interface.h | 3 + linden/indra/mac_crash_logger/mac_crash_logger.cpp | 7 +- linden/indra/mac_updater/FSCopyObject.h | 3 + linden/indra/mac_updater/GenLinkedList.h | 3 + linden/indra/mac_updater/MoreFilesX.h | 3 + linden/indra/mac_updater/mac_updater.cpp | 7 +- .../indra/newview/English.lproj/InfoPlist.strings | 4 +- linden/indra/newview/Info-SecondLife.plist | 2 +- linden/indra/newview/VertexCache.h | 3 + linden/indra/newview/VorbisFramework.h | 3 + linden/indra/newview/audiosettings.h | 3 + linden/indra/newview/fakevoicesoundsignal.cpp | 3 + linden/indra/newview/fakevoicesoundsignal.h | 3 + linden/indra/newview/files.lst | 6 +- linden/indra/newview/fmodwrapper.cpp | 3 + linden/indra/newview/head.cpp | 3 + linden/indra/newview/head.h | 5 +- linden/indra/newview/linux_tools/client-readme.txt | 2 - .../indra/newview/linux_tools/exposed-symbols.txt | 1 + linden/indra/newview/linux_tools/launch_url.sh | 3 +- linden/indra/newview/linux_tools/wrapper.sh | 38 +- linden/indra/newview/llagent.cpp | 96 +- linden/indra/newview/llagent.h | 8 +- linden/indra/newview/llagentdata.cpp | 3 + linden/indra/newview/llagentdata.h | 3 + linden/indra/newview/llagentpilot.cpp | 3 + linden/indra/newview/llagentpilot.h | 3 + linden/indra/newview/llanimalcontrols.cpp | 3 + linden/indra/newview/llanimalcontrols.h | 3 + linden/indra/newview/llappearance.h | 3 + linden/indra/newview/llassetuploadresponders.cpp | 28 +- linden/indra/newview/llassetuploadresponders.h | 5 +- linden/indra/newview/llasynchostbyname.cpp | 229 - linden/indra/newview/llasynchostbyname.h | 93 - linden/indra/newview/llaudiosourcevo.cpp | 21 +- linden/indra/newview/llaudiosourcevo.h | 3 + linden/indra/newview/llbbox.cpp | 3 + linden/indra/newview/llbbox.h | 3 + linden/indra/newview/llbox.cpp | 3 + linden/indra/newview/llbox.h | 3 + linden/indra/newview/llcallbacklist.cpp | 3 + linden/indra/newview/llcallbacklist.h | 3 + linden/indra/newview/llcallingcard.cpp | 5 +- linden/indra/newview/llcallingcard.h | 3 + linden/indra/newview/llcameraview.cpp | 3 + linden/indra/newview/llcameraview.h | 3 + linden/indra/newview/llcape.cpp | 3 + linden/indra/newview/llcape.h | 3 + linden/indra/newview/llcaphttpsender.cpp | 5 +- linden/indra/newview/llcaphttpsender.h | 5 +- linden/indra/newview/llchatbar.cpp | 7 +- linden/indra/newview/llchatbar.h | 3 + linden/indra/newview/llclassifiedinfo.cpp | 3 + linden/indra/newview/llclassifiedinfo.h | 3 + linden/indra/newview/llcloud.cpp | 3 + linden/indra/newview/llcloud.h | 3 + linden/indra/newview/llcolorscheme.cpp | 5 + linden/indra/newview/llcolorscheme.h | 4 + linden/indra/newview/llcolorswatch.cpp | 3 + linden/indra/newview/llcolorswatch.h | 3 + linden/indra/newview/llcommandhandler.cpp | 103 + linden/indra/newview/llcommandhandler.h | 85 + linden/indra/newview/llcompass.cpp | 3 + linden/indra/newview/llcompass.h | 3 + linden/indra/newview/llcompilequeue.cpp | 7 +- linden/indra/newview/llcompilequeue.h | 3 + linden/indra/newview/llconfirmationmanager.cpp | 3 + linden/indra/newview/llconfirmationmanager.h | 3 + linden/indra/newview/llconsole.cpp | 3 + linden/indra/newview/llconsole.h | 3 + linden/indra/newview/llcontainerview.cpp | 3 + linden/indra/newview/llcontainerview.h | 3 + linden/indra/newview/llcontroldef.cpp | 23 +- linden/indra/newview/llcubemap.cpp | 3 + linden/indra/newview/llcubemap.h | 3 + linden/indra/newview/llcurrencyuimanager.cpp | 20 +- linden/indra/newview/llcurrencyuimanager.h | 6 +- linden/indra/newview/llcylinder.cpp | 3 + linden/indra/newview/llcylinder.h | 3 + linden/indra/newview/lldebugmessagebox.cpp | 27 +- linden/indra/newview/lldebugmessagebox.h | 3 + linden/indra/newview/lldebugview.cpp | 3 + linden/indra/newview/lldebugview.h | 3 + linden/indra/newview/lldirpicker.cpp | 57 + linden/indra/newview/lldirpicker.h | 10 + linden/indra/newview/lldrawable.cpp | 3 + linden/indra/newview/lldrawable.h | 3 + linden/indra/newview/lldrawpool.cpp | 3 + linden/indra/newview/lldrawpool.h | 3 + linden/indra/newview/lldrawpoolalpha.cpp | 3 + linden/indra/newview/lldrawpoolalpha.h | 3 + linden/indra/newview/lldrawpoolavatar.cpp | 3 + linden/indra/newview/lldrawpoolavatar.h | 3 + linden/indra/newview/lldrawpoolbump.cpp | 3 + linden/indra/newview/lldrawpoolbump.h | 5 +- linden/indra/newview/lldrawpoolclouds.cpp | 3 + linden/indra/newview/lldrawpoolclouds.h | 3 + linden/indra/newview/lldrawpoolground.cpp | 3 + linden/indra/newview/lldrawpoolground.h | 3 + linden/indra/newview/lldrawpoolsimple.cpp | 3 + linden/indra/newview/lldrawpoolsimple.h | 3 + linden/indra/newview/lldrawpoolsky.cpp | 3 + linden/indra/newview/lldrawpoolsky.h | 3 + linden/indra/newview/lldrawpoolstars.cpp | 3 + linden/indra/newview/lldrawpoolstars.h | 3 + linden/indra/newview/lldrawpoolterrain.cpp | 3 + linden/indra/newview/lldrawpoolterrain.h | 3 + linden/indra/newview/lldrawpooltree.cpp | 3 + linden/indra/newview/lldrawpooltree.h | 3 + linden/indra/newview/lldrawpoolwater.cpp | 3 + linden/indra/newview/lldrawpoolwater.h | 3 + linden/indra/newview/lldriverparam.cpp | 3 + linden/indra/newview/lldriverparam.h | 3 + linden/indra/newview/lldynamictexture.cpp | 3 + linden/indra/newview/lldynamictexture.h | 3 + linden/indra/newview/llemote.cpp | 3 + linden/indra/newview/llemote.h | 3 + linden/indra/newview/lleventinfo.cpp | 3 + linden/indra/newview/lleventinfo.h | 3 + linden/indra/newview/lleventnotifier.cpp | 3 + linden/indra/newview/lleventnotifier.h | 3 + linden/indra/newview/lleventpoll.cpp | 6 +- linden/indra/newview/lleventpoll.h | 3 + linden/indra/newview/llface.cpp | 3 + linden/indra/newview/llface.h | 3 + linden/indra/newview/llface.inl | 3 + linden/indra/newview/llfasttimerview.cpp | 3 + linden/indra/newview/llfasttimerview.h | 3 + linden/indra/newview/llfeaturemanager.cpp | 3 + linden/indra/newview/llfeaturemanager.h | 3 + linden/indra/newview/llfilepicker.cpp | 273 +- linden/indra/newview/llfilepicker.h | 18 +- linden/indra/newview/llfirstuse.cpp | 3 + linden/indra/newview/llfirstuse.h | 3 + linden/indra/newview/llflexibleobject.cpp | 3 + linden/indra/newview/llflexibleobject.h | 3 + linden/indra/newview/llfloaterabout.cpp | 13 +- linden/indra/newview/llfloaterabout.h | 3 + linden/indra/newview/llfloateractivespeakers.cpp | 11 +- linden/indra/newview/llfloateractivespeakers.h | 3 + linden/indra/newview/llfloateranimpreview.cpp | 23 +- linden/indra/newview/llfloateranimpreview.h | 3 + linden/indra/newview/llfloaterauction.cpp | 5 +- linden/indra/newview/llfloaterauction.h | 3 + linden/indra/newview/llfloateravatarinfo.cpp | 32 +- linden/indra/newview/llfloateravatarinfo.h | 5 +- linden/indra/newview/llfloateravatarpicker.cpp | 3 + linden/indra/newview/llfloateravatarpicker.h | 3 + linden/indra/newview/llfloateravatartextures.cpp | 3 + linden/indra/newview/llfloateravatartextures.h | 3 + linden/indra/newview/llfloaterbuildoptions.cpp | 3 + linden/indra/newview/llfloaterbuildoptions.h | 3 + linden/indra/newview/llfloaterbump.cpp | 3 + linden/indra/newview/llfloaterbump.h | 3 + linden/indra/newview/llfloaterbuy.cpp | 27 +- linden/indra/newview/llfloaterbuy.h | 3 + linden/indra/newview/llfloaterbuycontents.cpp | 12 +- linden/indra/newview/llfloaterbuycontents.h | 3 + linden/indra/newview/llfloaterbuycurrency.cpp | 6 +- linden/indra/newview/llfloaterbuycurrency.h | 3 + linden/indra/newview/llfloaterbuyland.cpp | 14 +- linden/indra/newview/llfloaterbuyland.h | 3 + linden/indra/newview/llfloaterchat.cpp | 3 + linden/indra/newview/llfloaterchat.h | 3 + linden/indra/newview/llfloaterchatterbox.cpp | 5 +- linden/indra/newview/llfloaterchatterbox.h | 5 +- linden/indra/newview/llfloaterclothing.cpp | 3 + linden/indra/newview/llfloaterclothing.h | 3 + linden/indra/newview/llfloatercolorpicker.cpp | 14 +- linden/indra/newview/llfloatercolorpicker.h | 3 + linden/indra/newview/llfloatercustomize.cpp | 16 +- linden/indra/newview/llfloatercustomize.h | 3 + linden/indra/newview/llfloaterdirectory.cpp | 3 + linden/indra/newview/llfloaterdirectory.h | 3 + linden/indra/newview/llfloatereditui.cpp | 7 +- linden/indra/newview/llfloatereditui.h | 3 + linden/indra/newview/llfloaterfriends.cpp | 7 +- linden/indra/newview/llfloaterfriends.h | 3 + linden/indra/newview/llfloatergesture.cpp | 3 + linden/indra/newview/llfloatergesture.h | 3 + linden/indra/newview/llfloatergodtools.cpp | 7 +- linden/indra/newview/llfloatergodtools.h | 5 +- linden/indra/newview/llfloatergroupinfo.cpp | 31 + linden/indra/newview/llfloatergroupinfo.h | 7 +- linden/indra/newview/llfloatergroupinvite.cpp | 3 + linden/indra/newview/llfloatergroupinvite.h | 3 + linden/indra/newview/llfloatergroups.cpp | 3 + linden/indra/newview/llfloatergroups.h | 3 + linden/indra/newview/llfloaterhtml.cpp | 178 +- linden/indra/newview/llfloaterhtml.h | 23 +- linden/indra/newview/llfloaterhtmlfind.cpp | 206 - linden/indra/newview/llfloaterhtmlfind.h | 42 - linden/indra/newview/llfloaterhtmlhelp.cpp | 6 + linden/indra/newview/llfloaterhtmlhelp.h | 5 +- linden/indra/newview/llfloaterimagepreview.cpp | 3 + linden/indra/newview/llfloaterimagepreview.h | 3 + linden/indra/newview/llfloaterimport.cpp | 3 + linden/indra/newview/llfloaterimport.h | 3 + linden/indra/newview/llfloaterinspect.cpp | 57 +- linden/indra/newview/llfloaterinspect.h | 43 +- linden/indra/newview/llfloaterlagmeter.cpp | 365 ++ linden/indra/newview/llfloaterlagmeter.h | 80 + linden/indra/newview/llfloaterland.cpp | 402 +- linden/indra/newview/llfloaterland.h | 7 +- linden/indra/newview/llfloaterlandholdings.cpp | 3 + linden/indra/newview/llfloaterlandholdings.h | 3 + linden/indra/newview/llfloatermap.cpp | 47 +- linden/indra/newview/llfloatermap.h | 5 +- linden/indra/newview/llfloatermute.cpp | 3 + linden/indra/newview/llfloatermute.h | 3 + linden/indra/newview/llfloaternamedesc.cpp | 3 + linden/indra/newview/llfloaternamedesc.h | 3 + linden/indra/newview/llfloaternewim.cpp | 3 + linden/indra/newview/llfloaternewim.h | 3 + linden/indra/newview/llfloateropenobject.cpp | 5 +- linden/indra/newview/llfloateropenobject.h | 3 + linden/indra/newview/llfloaterpermissionsmgr.cpp | 3 + linden/indra/newview/llfloaterpermissionsmgr.h | 3 + linden/indra/newview/llfloaterpostcard.cpp | 6 +- linden/indra/newview/llfloaterpostcard.h | 3 + linden/indra/newview/llfloaterpreference.cpp | 3 + linden/indra/newview/llfloaterpreference.h | 3 + linden/indra/newview/llfloaterproperties.cpp | 73 +- linden/indra/newview/llfloaterproperties.h | 3 + linden/indra/newview/llfloaterregioninfo.cpp | 98 +- linden/indra/newview/llfloaterregioninfo.h | 3 + linden/indra/newview/llfloaterreleasemsg.cpp | 3 + linden/indra/newview/llfloaterreleasemsg.h | 3 + linden/indra/newview/llfloaterreporter.cpp | 13 +- linden/indra/newview/llfloaterreporter.h | 5 +- linden/indra/newview/llfloatersaveavatar.cpp | 3 + linden/indra/newview/llfloatersaveavatar.h | 3 + linden/indra/newview/llfloaterscriptdebug.cpp | 3 + linden/indra/newview/llfloaterscriptdebug.h | 3 + linden/indra/newview/llfloatersellland.cpp | 3 + linden/indra/newview/llfloatersellland.h | 3 + linden/indra/newview/llfloatersnapshot.cpp | 26 +- linden/indra/newview/llfloatersnapshot.h | 3 + linden/indra/newview/llfloatertelehub.cpp | 10 +- linden/indra/newview/llfloatertelehub.h | 3 + linden/indra/newview/llfloatertest.cpp | 6 +- linden/indra/newview/llfloatertest.h | 3 + linden/indra/newview/llfloatertools.cpp | 56 +- linden/indra/newview/llfloatertools.h | 7 +- linden/indra/newview/llfloatertopobjects.cpp | 3 + linden/indra/newview/llfloatertopobjects.h | 3 + linden/indra/newview/llfloatertos.cpp | 3 + linden/indra/newview/llfloatertos.h | 3 + linden/indra/newview/llfloatervoicewizard.cpp | 13 +- linden/indra/newview/llfloatervoicewizard.h | 3 + linden/indra/newview/llfloaterworldmap.cpp | 22 +- linden/indra/newview/llfloaterworldmap.h | 3 + linden/indra/newview/llfolderview.cpp | 19 +- linden/indra/newview/llfolderview.h | 5 +- linden/indra/newview/llfollowcam.cpp | 3 + linden/indra/newview/llfollowcam.h | 3 + linden/indra/newview/llframestats.cpp | 4 +- linden/indra/newview/llframestats.h | 3 + linden/indra/newview/llframestatview.cpp | 3 + linden/indra/newview/llframestatview.h | 3 + linden/indra/newview/llgenepool.cpp | 3 + linden/indra/newview/llgenepool.h | 3 + linden/indra/newview/llgesturemgr.cpp | 16 + linden/indra/newview/llgesturemgr.h | 4 + linden/indra/newview/llgivemoney.cpp | 12 +- linden/indra/newview/llgivemoney.h | 3 + linden/indra/newview/llglsandbox.cpp | 23 +- linden/indra/newview/llglslshader.cpp | 3 + linden/indra/newview/llglslshader.h | 3 + linden/indra/newview/llgroupmgr.cpp | 20 +- linden/indra/newview/llgroupmgr.h | 4 + linden/indra/newview/llgroupnotify.cpp | 3 + linden/indra/newview/llgroupnotify.h | 3 + linden/indra/newview/llhippo.cpp | 3 + linden/indra/newview/llhippo.h | 3 + linden/indra/newview/llhoverview.cpp | 3 + linden/indra/newview/llhoverview.h | 3 + linden/indra/newview/llhudconnector.cpp | 3 + linden/indra/newview/llhudconnector.h | 3 + linden/indra/newview/llhudeffect.cpp | 3 + linden/indra/newview/llhudeffect.h | 3 + linden/indra/newview/llhudeffectbeam.cpp | 3 + linden/indra/newview/llhudeffectbeam.h | 3 + linden/indra/newview/llhudeffectlookat.cpp | 3 + linden/indra/newview/llhudeffectlookat.h | 3 + linden/indra/newview/llhudeffectpointat.cpp | 3 + linden/indra/newview/llhudeffectpointat.h | 3 + linden/indra/newview/llhudeffecttrail.cpp | 3 + linden/indra/newview/llhudeffecttrail.h | 3 + linden/indra/newview/llhudicon.cpp | 3 + linden/indra/newview/llhudicon.h | 3 + linden/indra/newview/llhudmanager.cpp | 3 + linden/indra/newview/llhudmanager.h | 3 + linden/indra/newview/llhudobject.cpp | 3 + linden/indra/newview/llhudobject.h | 3 + linden/indra/newview/llhudrender.cpp | 3 + linden/indra/newview/llhudrender.h | 3 + linden/indra/newview/llhudtext.cpp | 3 + linden/indra/newview/llhudtext.h | 3 + linden/indra/newview/llhudview.cpp | 3 + linden/indra/newview/llhudview.h | 3 + linden/indra/newview/llimpanel.cpp | 13 +- linden/indra/newview/llimpanel.h | 3 + linden/indra/newview/llimview.cpp | 8 +- linden/indra/newview/llimview.h | 3 + linden/indra/newview/llinventoryactions.cpp | 7 + linden/indra/newview/llinventorybridge.cpp | 21 +- linden/indra/newview/llinventorybridge.h | 3 + linden/indra/newview/llinventoryclipboard.cpp | 3 + linden/indra/newview/llinventoryclipboard.h | 3 + linden/indra/newview/llinventorymodel.cpp | 68 +- linden/indra/newview/llinventorymodel.h | 12 + linden/indra/newview/llinventoryview.cpp | 30 +- linden/indra/newview/llinventoryview.h | 11 +- linden/indra/newview/lljoystickbutton.cpp | 3 + linden/indra/newview/lljoystickbutton.h | 3 + linden/indra/newview/lllandmarklist.cpp | 3 + linden/indra/newview/lllandmarklist.h | 3 + linden/indra/newview/lllightconstants.h | 3 + linden/indra/newview/lllocalanimationobject.cpp | 3 + linden/indra/newview/lllocalanimationobject.h | 3 + linden/indra/newview/lllogchat.cpp | 3 + linden/indra/newview/lllogchat.h | 3 + linden/indra/newview/llmanip.cpp | 19 +- linden/indra/newview/llmanip.h | 10 +- linden/indra/newview/llmaniprotate.cpp | 75 +- linden/indra/newview/llmaniprotate.h | 9 +- linden/indra/newview/llmanipscale.cpp | 116 +- linden/indra/newview/llmanipscale.h | 10 +- linden/indra/newview/llmaniptranslate.cpp | 74 +- linden/indra/newview/llmaniptranslate.h | 8 +- linden/indra/newview/llmapresponders.cpp | 3 + linden/indra/newview/llmapresponders.h | 3 + linden/indra/newview/llmediaremotectrl.cpp | 5 +- linden/indra/newview/llmediaremotectrl.h | 3 + linden/indra/newview/llmemoryview.cpp | 3 + linden/indra/newview/llmemoryview.h | 3 + linden/indra/newview/llmenucommands.cpp | 3 + linden/indra/newview/llmenucommands.h | 3 + linden/indra/newview/llmorphview.cpp | 3 + linden/indra/newview/llmorphview.h | 3 + linden/indra/newview/llmoveview.cpp | 3 + linden/indra/newview/llmoveview.h | 3 + linden/indra/newview/llmutelist.cpp | 7 +- linden/indra/newview/llmutelist.h | 5 +- linden/indra/newview/llnamebox.cpp | 5 +- linden/indra/newview/llnamebox.h | 3 + linden/indra/newview/llnameeditor.cpp | 3 + linden/indra/newview/llnameeditor.h | 3 + linden/indra/newview/llnamelistctrl.cpp | 6 +- linden/indra/newview/llnamelistctrl.h | 3 + linden/indra/newview/llnetmap.cpp | 20 +- linden/indra/newview/llnetmap.h | 3 + linden/indra/newview/llnotify.cpp | 25 +- linden/indra/newview/llnotify.h | 5 +- linden/indra/newview/lloverlaybar.cpp | 8 +- linden/indra/newview/lloverlaybar.h | 3 + linden/indra/newview/llpanelaudioprefs.cpp | 3 + linden/indra/newview/llpanelaudioprefs.h | 3 + linden/indra/newview/llpanelaudiovolume.cpp | 17 +- linden/indra/newview/llpanelaudiovolume.h | 3 + linden/indra/newview/llpanelavatar.cpp | 98 +- linden/indra/newview/llpanelavatar.h | 3 + linden/indra/newview/llpanelclassified.cpp | 13 +- linden/indra/newview/llpanelclassified.h | 3 + linden/indra/newview/llpanelcontents.cpp | 17 +- linden/indra/newview/llpanelcontents.h | 3 + linden/indra/newview/llpaneldebug.cpp | 3 + linden/indra/newview/llpaneldebug.h | 3 + linden/indra/newview/llpaneldirbrowser.cpp | 3 + linden/indra/newview/llpaneldirbrowser.h | 3 + linden/indra/newview/llpaneldirclassified.cpp | 3 + linden/indra/newview/llpaneldirclassified.h | 3 + linden/indra/newview/llpaneldirevents.cpp | 3 + linden/indra/newview/llpaneldirevents.h | 3 + linden/indra/newview/llpaneldirfind.cpp | 27 +- linden/indra/newview/llpaneldirfind.h | 3 + linden/indra/newview/llpaneldirgroups.cpp | 3 + linden/indra/newview/llpaneldirgroups.h | 3 + linden/indra/newview/llpaneldirland.cpp | 3 + linden/indra/newview/llpaneldirland.h | 3 + linden/indra/newview/llpaneldirpeople.cpp | 3 + linden/indra/newview/llpaneldirpeople.h | 3 + linden/indra/newview/llpaneldirplaces.cpp | 3 + linden/indra/newview/llpaneldirplaces.h | 3 + linden/indra/newview/llpaneldirpopular.cpp | 3 + linden/indra/newview/llpaneldirpopular.h | 3 + linden/indra/newview/llpaneldisplay.cpp | 9 +- linden/indra/newview/llpaneldisplay.h | 3 + linden/indra/newview/llpanelevent.cpp | 39 +- linden/indra/newview/llpanelevent.h | 4 +- linden/indra/newview/llpanelface.cpp | 421 +- linden/indra/newview/llpanelface.h | 19 +- linden/indra/newview/llpanelgeneral.cpp | 4 + linden/indra/newview/llpanelgeneral.h | 3 + linden/indra/newview/llpanelgroup.cpp | 15 +- linden/indra/newview/llpanelgroup.h | 5 +- linden/indra/newview/llpanelgroupgeneral.cpp | 179 +- linden/indra/newview/llpanelgroupgeneral.h | 6 +- linden/indra/newview/llpanelgroupinvite.cpp | 9 +- linden/indra/newview/llpanelgroupinvite.h | 3 + linden/indra/newview/llpanelgrouplandmoney.cpp | 205 +- linden/indra/newview/llpanelgrouplandmoney.h | 89 +- linden/indra/newview/llpanelgroupnotices.cpp | 7 +- linden/indra/newview/llpanelgroupnotices.h | 3 + linden/indra/newview/llpanelgrouproles.cpp | 3 + linden/indra/newview/llpanelgrouproles.h | 3 + linden/indra/newview/llpanelgroupvoting.cpp | 237 +- linden/indra/newview/llpanelgroupvoting.h | 3 + linden/indra/newview/llpanelinput.cpp | 3 + linden/indra/newview/llpanelinput.h | 3 + linden/indra/newview/llpanelinventory.cpp | 10 +- linden/indra/newview/llpanelinventory.h | 3 + linden/indra/newview/llpanelland.cpp | 9 +- linden/indra/newview/llpanelland.h | 3 + linden/indra/newview/llpanellandobjects.cpp | 3 + linden/indra/newview/llpanellandobjects.h | 3 + linden/indra/newview/llpanellandoptions.cpp | 3 + linden/indra/newview/llpanellandoptions.h | 3 + linden/indra/newview/llpanellogin.cpp | 25 +- linden/indra/newview/llpanellogin.h | 7 +- linden/indra/newview/llpanelmorph.cpp | 3 + linden/indra/newview/llpanelmorph.h | 3 + linden/indra/newview/llpanelmsgs.cpp | 3 + linden/indra/newview/llpanelmsgs.h | 3 + linden/indra/newview/llpanelnetwork.cpp | 3 + linden/indra/newview/llpanelnetwork.h | 3 + linden/indra/newview/llpanelobject.cpp | 23 +- linden/indra/newview/llpanelobject.h | 3 + linden/indra/newview/llpanelpermissions.cpp | 122 +- linden/indra/newview/llpanelpermissions.h | 7 +- linden/indra/newview/llpanelpick.cpp | 13 +- linden/indra/newview/llpanelpick.h | 3 + linden/indra/newview/llpanelplace.cpp | 38 +- linden/indra/newview/llpanelplace.h | 3 + linden/indra/newview/llpanelvolume.cpp | 3 + linden/indra/newview/llpanelvolume.h | 3 + linden/indra/newview/llpanelweb.cpp | 5 +- linden/indra/newview/llpanelweb.h | 3 + linden/indra/newview/llpatchvertexarray.cpp | 3 + linden/indra/newview/llpatchvertexarray.h | 3 + linden/indra/newview/llpolymesh.cpp | 3 + linden/indra/newview/llpolymesh.h | 3 + linden/indra/newview/llpolymorph.cpp | 3 + linden/indra/newview/llpolymorph.h | 3 + linden/indra/newview/llprefschat.cpp | 3 + linden/indra/newview/llprefschat.h | 3 + linden/indra/newview/llprefsim.cpp | 3 + linden/indra/newview/llprefsim.h | 3 + linden/indra/newview/llprefsvoice.cpp | 3 + linden/indra/newview/llprefsvoice.h | 3 + linden/indra/newview/llpreview.cpp | 3 + linden/indra/newview/llpreview.h | 3 + linden/indra/newview/llpreviewanim.cpp | 3 + linden/indra/newview/llpreviewanim.h | 3 + linden/indra/newview/llpreviewgesture.cpp | 90 +- linden/indra/newview/llpreviewgesture.h | 4 + linden/indra/newview/llpreviewlandmark.cpp | 5 +- linden/indra/newview/llpreviewlandmark.h | 3 + linden/indra/newview/llpreviewnotecard.cpp | 13 +- linden/indra/newview/llpreviewnotecard.h | 3 + linden/indra/newview/llpreviewscript.cpp | 84 +- linden/indra/newview/llpreviewscript.h | 6 + linden/indra/newview/llpreviewsound.cpp | 3 + linden/indra/newview/llpreviewsound.h | 3 + linden/indra/newview/llpreviewtexture.cpp | 3 + linden/indra/newview/llpreviewtexture.h | 3 + linden/indra/newview/llprogressview.cpp | 3 + linden/indra/newview/llprogressview.h | 3 + linden/indra/newview/llregionposition.cpp | 3 + linden/indra/newview/llregionposition.h | 3 + linden/indra/newview/llresourcedata.h | 3 + linden/indra/newview/llroam.cpp | 3 + linden/indra/newview/llroam.h | 3 + linden/indra/newview/llsavedsettingsglue.cpp | 3 + linden/indra/newview/llsavedsettingsglue.h | 3 + linden/indra/newview/llselectmgr.cpp | 3287 +++++++------- linden/indra/newview/llselectmgr.h | 390 +- linden/indra/newview/llsky.cpp | 3 + linden/indra/newview/llsky.h | 3 + linden/indra/newview/llspatialpartition.cpp | 3 + linden/indra/newview/llspatialpartition.h | 3 + linden/indra/newview/llsphere.cpp | 3 + linden/indra/newview/llsphere.h | 3 + linden/indra/newview/llsprite.cpp | 3 + linden/indra/newview/llsprite.h | 3 + linden/indra/newview/llsrv.cpp | 353 +- linden/indra/newview/llsrv.h | 48 +- linden/indra/newview/llstartup.cpp | 221 +- linden/indra/newview/llstartup.h | 11 + linden/indra/newview/llstatbar.cpp | 3 + linden/indra/newview/llstatbar.h | 3 + linden/indra/newview/llstatgraph.cpp | 3 + linden/indra/newview/llstatgraph.h | 3 + linden/indra/newview/llstatusbar.cpp | 15 +- linden/indra/newview/llstatusbar.h | 3 + linden/indra/newview/llstatview.cpp | 3 + linden/indra/newview/llstatview.h | 3 + linden/indra/newview/llsurface.cpp | 3 + linden/indra/newview/llsurface.h | 3 + linden/indra/newview/llsurfacepatch.cpp | 3 + linden/indra/newview/llsurfacepatch.h | 3 + linden/indra/newview/lltable.h | 3 + linden/indra/newview/lltexlayer.cpp | 3 + linden/indra/newview/lltexlayer.h | 3 + linden/indra/newview/lltexturecache.cpp | 3 + linden/indra/newview/lltexturecache.h | 3 + linden/indra/newview/lltexturectrl.cpp | 11 +- linden/indra/newview/lltexturectrl.h | 3 + linden/indra/newview/lltexturefetch.cpp | 3 + linden/indra/newview/lltexturefetch.h | 3 + linden/indra/newview/lltextureview.cpp | 21 +- linden/indra/newview/lltextureview.h | 3 + linden/indra/newview/lltool.cpp | 3 + linden/indra/newview/lltool.h | 3 + linden/indra/newview/lltoolbar.cpp | 3 + linden/indra/newview/lltoolbar.h | 3 + linden/indra/newview/lltoolbrush.cpp | 6 +- linden/indra/newview/lltoolbrush.h | 3 + linden/indra/newview/lltoolcomp.cpp | 9 +- linden/indra/newview/lltoolcomp.h | 3 + linden/indra/newview/lltooldraganddrop.cpp | 3 + linden/indra/newview/lltooldraganddrop.h | 3 + linden/indra/newview/lltoolface.cpp | 3 + linden/indra/newview/lltoolface.h | 3 + linden/indra/newview/lltoolfocus.cpp | 17 +- linden/indra/newview/lltoolfocus.h | 3 + linden/indra/newview/lltoolgrab.cpp | 6 +- linden/indra/newview/lltoolgrab.h | 3 + linden/indra/newview/lltoolgun.cpp | 3 + linden/indra/newview/lltoolgun.h | 3 + linden/indra/newview/lltoolindividual.cpp | 10 +- linden/indra/newview/lltoolindividual.h | 3 + linden/indra/newview/lltoolmgr.cpp | 14 +- linden/indra/newview/lltoolmgr.h | 3 + linden/indra/newview/lltoolmorph.cpp | 3 + linden/indra/newview/lltoolmorph.h | 3 + linden/indra/newview/lltoolobjpicker.cpp | 3 + linden/indra/newview/lltoolobjpicker.h | 3 + linden/indra/newview/lltoolpie.cpp | 12 +- linden/indra/newview/lltoolpie.h | 3 + linden/indra/newview/lltoolpipette.cpp | 3 + linden/indra/newview/lltoolpipette.h | 3 + linden/indra/newview/lltoolplacer.cpp | 6 +- linden/indra/newview/lltoolplacer.h | 3 + linden/indra/newview/lltoolselect.cpp | 11 + linden/indra/newview/lltoolselect.h | 3 + linden/indra/newview/lltoolselectland.cpp | 6 +- linden/indra/newview/lltoolselectland.h | 3 + linden/indra/newview/lltoolselectrect.cpp | 3 + linden/indra/newview/lltoolselectrect.h | 3 + linden/indra/newview/lltoolview.cpp | 6 +- linden/indra/newview/lltoolview.h | 3 + linden/indra/newview/lltracker.cpp | 3 + linden/indra/newview/lltracker.h | 3 + linden/indra/newview/lluiconstants.h | 3 + linden/indra/newview/lluploaddialog.cpp | 3 + linden/indra/newview/lluploaddialog.h | 3 + linden/indra/newview/llurl.cpp | 4 +- linden/indra/newview/llurl.h | 3 + linden/indra/newview/llurldispatcher.cpp | 326 ++ linden/indra/newview/llurldispatcher.h | 55 + linden/indra/newview/llurlsimstring.cpp | 171 + linden/indra/newview/llurlsimstring.h | 81 + linden/indra/newview/llurlwhitelist.cpp | 3 + linden/indra/newview/llurlwhitelist.h | 3 + linden/indra/newview/lluserauth.cpp | 8 +- linden/indra/newview/lluserauth.h | 3 + linden/indra/newview/llvelocitybar.cpp | 3 + linden/indra/newview/llvelocitybar.h | 3 + linden/indra/newview/llviewchildren.cpp | 3 + linden/indra/newview/llviewchildren.h | 3 + linden/indra/newview/llviewerassetstorage.cpp | 3 + linden/indra/newview/llviewerassetstorage.h | 3 + linden/indra/newview/llviewerbuild.h | 3 + linden/indra/newview/llviewercamera.cpp | 5 +- linden/indra/newview/llviewercamera.h | 4 +- linden/indra/newview/llviewercontrol.cpp | 37 +- linden/indra/newview/llviewercontrol.h | 3 + linden/indra/newview/llviewerdisplay.cpp | 7 + linden/indra/newview/llviewerdisplay.h | 3 + linden/indra/newview/llviewergenericmessage.cpp | 5 +- linden/indra/newview/llviewergenericmessage.h | 5 +- linden/indra/newview/llviewergesture.cpp | 3 + linden/indra/newview/llviewergesture.h | 3 + linden/indra/newview/llviewerimage.cpp | 3 + linden/indra/newview/llviewerimage.h | 3 + linden/indra/newview/llviewerimagelist.cpp | 201 +- linden/indra/newview/llviewerimagelist.h | 3 + linden/indra/newview/llviewerinventory.cpp | 3 + linden/indra/newview/llviewerinventory.h | 3 + linden/indra/newview/llviewerjoint.cpp | 3 + linden/indra/newview/llviewerjoint.h | 3 + linden/indra/newview/llviewerjointattachment.cpp | 3 + linden/indra/newview/llviewerjointattachment.h | 3 + linden/indra/newview/llviewerjointmesh.cpp | 3 + linden/indra/newview/llviewerjointmesh.h | 3 + linden/indra/newview/llviewerjointmesh_sse.cpp | 5 +- linden/indra/newview/llviewerjointmesh_sse2.cpp | 5 +- linden/indra/newview/llviewerjointmesh_vec.cpp | 5 +- linden/indra/newview/llviewerjointshape.cpp | 3 + linden/indra/newview/llviewerjointshape.h | 3 + linden/indra/newview/llviewerjoystick.cpp | 3 + linden/indra/newview/llviewerjoystick.h | 3 + linden/indra/newview/llviewerkeyboard.cpp | 3 + linden/indra/newview/llviewerkeyboard.h | 3 + linden/indra/newview/llviewerlayer.cpp | 3 + linden/indra/newview/llviewerlayer.h | 3 + linden/indra/newview/llviewermenu.cpp | 829 +--- linden/indra/newview/llviewermenu.h | 3 + linden/indra/newview/llviewermenufile.cpp | 5 +- linden/indra/newview/llviewermenufile.h | 3 + linden/indra/newview/llviewermessage.cpp | 34 +- linden/indra/newview/llviewermessage.h | 3 + linden/indra/newview/llviewernetwork.cpp | 3 + linden/indra/newview/llviewernetwork.h | 3 + linden/indra/newview/llviewerobject.cpp | 80 +- linden/indra/newview/llviewerobject.h | 9 + linden/indra/newview/llviewerobjectlist.cpp | 22 +- linden/indra/newview/llviewerobjectlist.h | 3 + linden/indra/newview/llviewerparcelmgr.cpp | 5 +- linden/indra/newview/llviewerparcelmgr.h | 5 +- linden/indra/newview/llviewerparceloverlay.cpp | 3 + linden/indra/newview/llviewerparceloverlay.h | 3 + linden/indra/newview/llviewerpartsim.cpp | 43 +- linden/indra/newview/llviewerpartsim.h | 17 +- linden/indra/newview/llviewerpartsource.cpp | 13 +- linden/indra/newview/llviewerpartsource.h | 13 +- .../indra/newview/llviewerprecompiledheaders.cpp | 3 + linden/indra/newview/llviewerprecompiledheaders.h | 3 + linden/indra/newview/llviewerregion.cpp | 90 + linden/indra/newview/llviewerregion.h | 10 + linden/indra/newview/llviewerstats.cpp | 14 +- linden/indra/newview/llviewerstats.h | 5 +- linden/indra/newview/llviewertexteditor.cpp | 3 + linden/indra/newview/llviewertexteditor.h | 5 +- linden/indra/newview/llviewertextureanim.cpp | 3 + linden/indra/newview/llviewertextureanim.h | 3 + linden/indra/newview/llviewerthrottle.cpp | 3 + linden/indra/newview/llviewerthrottle.h | 3 + linden/indra/newview/llvieweruictrlfactory.cpp | 3 + linden/indra/newview/llvieweruictrlfactory.h | 3 + linden/indra/newview/llviewervisualparam.cpp | 3 + linden/indra/newview/llviewervisualparam.h | 3 + linden/indra/newview/llviewerwindow.cpp | 98 +- linden/indra/newview/llviewerwindow.h | 6 +- linden/indra/newview/llvlcomposition.cpp | 3 + linden/indra/newview/llvlcomposition.h | 3 + linden/indra/newview/llvlmanager.cpp | 3 + linden/indra/newview/llvlmanager.h | 3 + linden/indra/newview/llvoavatar.cpp | 3 + linden/indra/newview/llvoavatar.h | 3 + linden/indra/newview/llvocache.cpp | 3 + linden/indra/newview/llvocache.h | 3 + linden/indra/newview/llvoclouds.cpp | 3 + linden/indra/newview/llvoclouds.h | 3 + linden/indra/newview/llvograss.cpp | 3 + linden/indra/newview/llvograss.h | 3 + linden/indra/newview/llvoground.cpp | 3 + linden/indra/newview/llvoground.h | 3 + linden/indra/newview/llvoiceclient.cpp | 7 +- linden/indra/newview/llvoiceclient.h | 6 +- linden/indra/newview/llvoiceremotectrl.cpp | 3 + linden/indra/newview/llvoiceremotectrl.h | 3 + linden/indra/newview/llvoicevisualizer.cpp | 3 + linden/indra/newview/llvoicevisualizer.h | 3 + linden/indra/newview/llvoinventorylistener.cpp | 3 + linden/indra/newview/llvoinventorylistener.h | 3 + linden/indra/newview/llvopartgroup.cpp | 3 + linden/indra/newview/llvopartgroup.h | 3 + linden/indra/newview/llvosky.cpp | 3 + linden/indra/newview/llvosky.h | 3 + linden/indra/newview/llvostars.cpp | 3 + linden/indra/newview/llvostars.h | 3 + linden/indra/newview/llvosurfacepatch.cpp | 3 + linden/indra/newview/llvosurfacepatch.h | 3 + linden/indra/newview/llvotextbubble.cpp | 3 + linden/indra/newview/llvotextbubble.h | 3 + linden/indra/newview/llvotree.cpp | 3 + linden/indra/newview/llvotree.h | 3 + linden/indra/newview/llvotreenew.h | 3 + linden/indra/newview/llvovolume.cpp | 3 + linden/indra/newview/llvovolume.h | 3 + linden/indra/newview/llvowater.cpp | 3 + linden/indra/newview/llvowater.h | 3 + linden/indra/newview/llwearable.cpp | 3 + linden/indra/newview/llwearable.h | 11 +- linden/indra/newview/llwearablelist.cpp | 7 +- linden/indra/newview/llwearablelist.h | 5 +- linden/indra/newview/llweb.cpp | 3 + linden/indra/newview/llweb.h | 3 + linden/indra/newview/llwebbrowserctrl.cpp | 56 +- linden/indra/newview/llwebbrowserctrl.h | 6 +- linden/indra/newview/llwind.cpp | 3 + linden/indra/newview/llwind.h | 3 + linden/indra/newview/llwindebug.cpp | 3 + linden/indra/newview/llwindebug.h | 3 + linden/indra/newview/llworld.cpp | 3 + linden/indra/newview/llworld.h | 3 + linden/indra/newview/llworldmap.cpp | 3 + linden/indra/newview/llworldmap.h | 3 + linden/indra/newview/llworldmapview.cpp | 431 +- linden/indra/newview/llworldmapview.h | 10 +- linden/indra/newview/llxmlrpctransaction.cpp | 3 + linden/indra/newview/llxmlrpctransaction.h | 3 + linden/indra/newview/macmain.h | 3 + linden/indra/newview/macutil_Prefix.h | 3 + .../newview/macview.xcodeproj/project.pbxproj | 42 +- linden/indra/newview/macview_Prefix.h | 3 + linden/indra/newview/moviemaker.cpp | 7 +- linden/indra/newview/moviemaker.h | 3 + linden/indra/newview/newview.vcproj | 47 +- linden/indra/newview/newview_vc8.vcproj | 35 +- linden/indra/newview/noise.cpp | 3 + linden/indra/newview/noise.h | 3 + linden/indra/newview/pipeline.cpp | 30 +- linden/indra/newview/pipeline.h | 10 +- linden/indra/newview/postbuild.bat | 4 + linden/indra/newview/randgauss.h | 5 +- linden/indra/newview/releasenotes.txt | 260 +- linden/indra/newview/res/newViewRes.rc | 8 +- linden/indra/newview/secondlife-i686.supp | 27 +- linden/indra/newview/skins/textures/textures.xml | 5 + linden/indra/newview/skins/xui/de/alerts.xml | 2732 ++++++------ .../indra/newview/skins/xui/de/floater_about.xml | 17 +- .../newview/skins/xui/de/floater_about_land.xml | 394 +- .../skins/xui/de/floater_active_speakers.xml | 11 + .../skins/xui/de/floater_animation_preview.xml | 101 +- .../indra/newview/skins/xui/de/floater_auction.xml | 14 +- .../newview/skins/xui/de/floater_audio_volume.xml | 4 + .../newview/skins/xui/de/floater_avatar_picker.xml | 10 +- .../skins/xui/de/floater_avatar_textures.xml | 22 +- .../newview/skins/xui/de/floater_build_options.xml | 7 +- .../indra/newview/skins/xui/de/floater_bumps.xml | 14 +- .../newview/skins/xui/de/floater_buy_contents.xml | 15 +- .../newview/skins/xui/de/floater_buy_currency.xml | 41 +- .../newview/skins/xui/de/floater_buy_land.xml | 146 +- .../newview/skins/xui/de/floater_buy_object.xml | 18 +- .../newview/skins/xui/de/floater_chat_history.xml | 4 +- .../newview/skins/xui/de/floater_chatterbox.xml | 2 + .../newview/skins/xui/de/floater_clothing.xml | 4 +- .../newview/skins/xui/de/floater_color_picker.xml | 3 +- .../newview/skins/xui/de/floater_critical.xml | 4 +- .../newview/skins/xui/de/floater_customize.xml | 440 +- .../skins/xui/de/floater_device_settings.xml | 2 + .../newview/skins/xui/de/floater_directory.xml | 196 +- .../indra/newview/skins/xui/de/floater_friends.xml | 41 +- .../indra/newview/skins/xui/de/floater_gesture.xml | 8 +- .../newview/skins/xui/de/floater_god_tools.xml | 123 +- .../newview/skins/xui/de/floater_group_info.xml | 111 +- .../indra/newview/skins/xui/de/floater_groups.xml | 14 +- linden/indra/newview/skins/xui/de/floater_html.xml | 22 +- .../newview/skins/xui/de/floater_html_help.xml | 2 +- linden/indra/newview/skins/xui/de/floater_im.xml | 21 + .../newview/skins/xui/de/floater_image_preview.xml | 20 +- .../indra/newview/skins/xui/de/floater_import.xml | 4 +- .../skins/xui/de/floater_instant_message.xml | 24 +- .../xui/de/floater_instant_message_ad_hoc.xml | 43 + .../skins/xui/de/floater_instant_message_group.xml | 44 + .../newview/skins/xui/de/floater_inventory.xml | 15 +- .../xui/de/floater_inventory_item_properties.xml | 30 +- .../skins/xui/de/floater_inventory_view_finder.xml | 12 +- .../newview/skins/xui/de/floater_land_holdings.xml | 18 +- .../skins/xui/de/floater_live_lsleditor.xml | 5 +- .../newview/skins/xui/de/floater_moveview.xml | 19 +- linden/indra/newview/skins/xui/de/floater_mute.xml | 10 +- .../newview/skins/xui/de/floater_my_friends.xml | 7 + .../skins/xui/de/floater_name_description.xml | 2 +- .../skins/xui/de/floater_new_outfit_dialog.xml | 16 +- .../newview/skins/xui/de/floater_openobject.xml | 4 +- linden/indra/newview/skins/xui/de/floater_pay.xml | 14 +- .../newview/skins/xui/de/floater_pay_object.xml | 10 +- .../newview/skins/xui/de/floater_postcard.xml | 26 +- .../newview/skins/xui/de/floater_preferences.xml | 3 +- .../skins/xui/de/floater_preview_animation.xml | 10 +- .../xui/de/floater_preview_embedded_texture.xml | 7 +- .../xui/de/floater_preview_existing_landmark.xml | 7 +- .../skins/xui/de/floater_preview_gesture.xml | 17 +- .../skins/xui/de/floater_preview_new_landmark.xml | 7 +- .../skins/xui/de/floater_preview_notecard.xml | 8 +- .../de/floater_preview_notecard_keep_discard.xml | 7 +- .../newview/skins/xui/de/floater_preview_sound.xml | 12 +- .../skins/xui/de/floater_preview_texture.xml | 4 +- .../de/floater_preview_texture_keep_discard.xml | 4 +- .../skins/xui/de/floater_price_for_listing.xml | 14 +- linden/indra/newview/skins/xui/de/floater_rate.xml | 16 +- .../newview/skins/xui/de/floater_report_abuse.xml | 43 +- .../newview/skins/xui/de/floater_report_bug.xml | 42 +- .../newview/skins/xui/de/floater_script_debug.xml | 2 +- .../skins/xui/de/floater_script_ed_panel.xml | 26 +- .../newview/skins/xui/de/floater_script_queue.xml | 2 +- .../newview/skins/xui/de/floater_script_search.xml | 2 +- .../newview/skins/xui/de/floater_select_key.xml | 7 + .../newview/skins/xui/de/floater_sell_land.xml | 54 +- .../skins/xui/de/floater_settings_debug.xml | 6 +- .../skins/xui/de/floater_sim_release_message.xml | 16 + .../newview/skins/xui/de/floater_snapshot.xml | 31 +- .../newview/skins/xui/de/floater_sound_preview.xml | 4 +- .../indra/newview/skins/xui/de/floater_telehub.xml | 16 +- linden/indra/newview/skins/xui/de/floater_test.xml | 2 + .../newview/skins/xui/de/floater_texture_ctrl.xml | 8 +- .../indra/newview/skins/xui/de/floater_tools.xml | 24 +- .../newview/skins/xui/de/floater_top_objects.xml | 51 +- linden/indra/newview/skins/xui/de/floater_tos.xml | 10 +- .../newview/skins/xui/de/floater_voice_wizard.xml | 9 + .../skins/xui/de/floater_wearable_save_as.xml | 4 +- .../newview/skins/xui/de/floater_world_map.xml | 46 +- .../indra/newview/skins/xui/de/menu_inventory.xml | 31 +- .../newview/skins/xui/de/menu_pie_attachment.xml | 2 +- .../indra/newview/skins/xui/de/menu_pie_avatar.xml | 8 +- .../indra/newview/skins/xui/de/menu_pie_land.xml | 4 +- .../indra/newview/skins/xui/de/menu_pie_object.xml | 13 +- .../indra/newview/skins/xui/de/menu_pie_self.xml | 10 +- linden/indra/newview/skins/xui/de/menu_viewer.xml | 99 +- linden/indra/newview/skins/xui/de/need_to_long.xml | 160 + .../newview/skins/xui/de/need_to_translate.xml | 2551 ++++++++++- .../indra/newview/skins/xui/de/need_to_update.xml | 855 ++-- linden/indra/newview/skins/xui/de/notify.xml | 498 ++- linden/indra/newview/skins/xui/de/panel_audio.xml | 11 + .../newview/skins/xui/de/panel_audio_device.xml | 19 + linden/indra/newview/skins/xui/de/panel_avatar.xml | 120 +- .../skins/xui/de/panel_avatar_classified.xml | 20 +- .../newview/skins/xui/de/panel_avatar_pick.xml | 6 +- .../indra/newview/skins/xui/de/panel_chat_bar.xml | 11 +- .../newview/skins/xui/de/panel_classified.xml | 16 +- linden/indra/newview/skins/xui/de/panel_event.xml | 43 +- .../indra/newview/skins/xui/de/panel_friends.xml | 32 + linden/indra/newview/skins/xui/de/panel_group.xml | 7 +- .../newview/skins/xui/de/panel_group_finder.xml | 6 +- .../newview/skins/xui/de/panel_group_general.xml | 62 +- .../newview/skins/xui/de/panel_group_invite.xml | 21 +- .../skins/xui/de/panel_group_land_money.xml | 48 +- .../newview/skins/xui/de/panel_group_notices.xml | 48 +- .../newview/skins/xui/de/panel_group_roles.xml | 62 +- .../newview/skins/xui/de/panel_group_voting.xml | 93 +- linden/indra/newview/skins/xui/de/panel_groups.xml | 15 + .../newview/skins/xui/de/panel_land_covenant.xml | 12 +- linden/indra/newview/skins/xui/de/panel_login.xml | 16 +- .../newview/skins/xui/de/panel_master_volume.xml | 6 + .../newview/skins/xui/de/panel_media_remote.xml | 17 +- .../newview/skins/xui/de/panel_music_remote.xml | 17 +- .../newview/skins/xui/de/panel_overlaybar.xml | 16 +- linden/indra/newview/skins/xui/de/panel_place.xml | 18 +- .../newview/skins/xui/de/panel_place_small.xml | 6 +- .../skins/xui/de/panel_preferences_audio.xml | 35 +- .../skins/xui/de/panel_preferences_chat.xml | 17 +- .../skins/xui/de/panel_preferences_general.xml | 75 +- .../skins/xui/de/panel_preferences_graphics1.xml | 30 +- .../skins/xui/de/panel_preferences_graphics2.xml | 30 +- .../skins/xui/de/panel_preferences_graphics3.xml | 28 +- .../newview/skins/xui/de/panel_preferences_im.xml | 30 +- .../skins/xui/de/panel_preferences_input.xml | 16 +- .../skins/xui/de/panel_preferences_network.xml | 30 +- .../skins/xui/de/panel_preferences_popups.xml | 23 +- .../skins/xui/de/panel_preferences_voice.xml | 37 + .../newview/skins/xui/de/panel_region_covenant.xml | 20 +- .../newview/skins/xui/de/panel_region_debug.xml | 20 +- .../newview/skins/xui/de/panel_region_estate.xml | 34 +- .../newview/skins/xui/de/panel_region_general.xml | 25 +- .../newview/skins/xui/de/panel_region_terrain.xml | 12 +- .../newview/skins/xui/de/panel_region_texture.xml | 39 +- .../newview/skins/xui/de/panel_scrolling_param.xml | 4 +- .../newview/skins/xui/de/panel_settings_chat.xml | 10 +- .../newview/skins/xui/de/panel_settings_im.xml | 4 +- .../skins/xui/de/panel_settings_network.xml | 23 +- .../newview/skins/xui/de/panel_settings_web.xml | 31 +- .../newview/skins/xui/de/panel_status_bar.xml | 23 +- .../indra/newview/skins/xui/de/panel_toolbar.xml | 25 +- .../indra/newview/skins/xui/de/panel_top_pick.xml | 4 +- .../newview/skins/xui/de/panel_voice_enable.xml | 23 + .../newview/skins/xui/de/panel_voice_options.xml | 23 + .../newview/skins/xui/de/panel_voice_remote.xml | 9 + linden/indra/newview/skins/xui/de/role_actions.xml | 266 +- linden/indra/newview/skins/xui/de/untranslated.xml | Bin 69 -> 344459 bytes linden/indra/newview/skins/xui/en-us/alerts.xml | 73 +- .../newview/skins/xui/en-us/floater_about.xml | 3 +- .../newview/skins/xui/en-us/floater_about_land.xml | 221 +- .../skins/xui/en-us/floater_animation_preview.xml | 71 +- .../skins/xui/en-us/floater_avatar_picker.xml | 18 +- .../skins/xui/en-us/floater_buy_contents.xml | 3 + .../skins/xui/en-us/floater_buy_currency.xml | 13 +- .../newview/skins/xui/en-us/floater_buy_land.xml | 43 +- .../newview/skins/xui/en-us/floater_buy_object.xml | 4 + .../skins/xui/en-us/floater_chat_history.xml | 2 +- .../skins/xui/en-us/floater_color_picker.xml | 24 +- .../newview/skins/xui/en-us/floater_customize.xml | 27 +- .../newview/skins/xui/en-us/floater_directory.xml | 120 +- .../newview/skins/xui/en-us/floater_friends.xml | 1 + .../newview/skins/xui/en-us/floater_gesture.xml | 15 +- .../newview/skins/xui/en-us/floater_god_tools.xml | 2 +- .../indra/newview/skins/xui/en-us/floater_html.xml | 25 +- .../skins/xui/en-us/floater_image_preview.xml | 16 +- .../newview/skins/xui/en-us/floater_inventory.xml | 3 +- .../en-us/floater_inventory_item_properties.xml | 4 + .../xui/en-us/floater_inventory_view_finder.xml | 8 +- .../newview/skins/xui/en-us/floater_lagmeter.xml | 426 ++ .../skins/xui/en-us/floater_live_lsleditor.xml | 2 + .../newview/skins/xui/en-us/floater_moveview.xml | 4 +- .../indra/newview/skins/xui/en-us/floater_mute.xml | 6 +- .../indra/newview/skins/xui/en-us/floater_pay.xml | 38 +- .../newview/skins/xui/en-us/floater_postcard.xml | 10 +- .../skins/xui/en-us/floater_preferences.xml | 19 +- .../skins/xui/en-us/floater_preview_gesture.xml | 3 + .../skins/xui/en-us/floater_preview_notecard.xml | 4 +- .../floater_preview_notecard_keep_discard.xml | 1 + .../skins/xui/en-us/floater_preview_sound.xml | 27 +- .../skins/xui/en-us/floater_price_for_listing.xml | 16 +- .../skins/xui/en-us/floater_report_abuse.xml | 98 +- .../newview/skins/xui/en-us/floater_report_bug.xml | 76 +- .../skins/xui/en-us/floater_script_ed_panel.xml | 8 +- .../skins/xui/en-us/floater_script_search.xml | 10 +- .../newview/skins/xui/en-us/floater_sell_land.xml | 24 +- .../newview/skins/xui/en-us/floater_snapshot.xml | 3 +- .../skins/xui/en-us/floater_sound_preview.xml | 14 +- .../indra/newview/skins/xui/en-us/floater_test.xml | 46 +- .../skins/xui/en-us/floater_texture_ctrl.xml | 5 +- .../newview/skins/xui/en-us/floater_tools.xml | 345 +- .../skins/xui/en-us/floater_voice_wizard.xml | 20 +- .../newview/skins/xui/en-us/floater_world_map.xml | 32 +- .../indra/newview/skins/xui/en-us/menu_viewer.xml | 65 +- linden/indra/newview/skins/xui/en-us/notify.xml | 2 +- .../newview/skins/xui/en-us/panel_audio_device.xml | 3 +- .../indra/newview/skins/xui/en-us/panel_avatar.xml | 76 +- .../skins/xui/en-us/panel_avatar_classified.xml | 8 +- .../newview/skins/xui/en-us/panel_avatar_pick.xml | 6 +- .../newview/skins/xui/en-us/panel_classified.xml | 2 + .../indra/newview/skins/xui/en-us/panel_event.xml | 11 +- .../newview/skins/xui/en-us/panel_friends.xml | 2 +- .../indra/newview/skins/xui/en-us/panel_group.xml | 12 +- .../skins/xui/en-us/panel_group_general.xml | 95 +- .../newview/skins/xui/en-us/panel_group_invite.xml | 42 +- .../skins/xui/en-us/panel_group_land_money.xml | 4 +- .../newview/skins/xui/en-us/panel_group_roles.xml | 10 +- .../newview/skins/xui/en-us/panel_group_voting.xml | 68 +- .../indra/newview/skins/xui/en-us/panel_place.xml | 8 +- .../skins/xui/en-us/panel_preferences_chat.xml | 61 +- .../xui/en-us/panel_preferences_graphics1.xml | 20 +- .../xui/en-us/panel_preferences_graphics3.xml | 34 +- .../skins/xui/en-us/panel_preferences_im.xml | 2 +- .../skins/xui/en-us/panel_preferences_network.xml | 55 +- .../skins/xui/en-us/panel_preferences_popups.xml | 8 +- .../skins/xui/en-us/panel_region_covenant.xml | 58 +- .../newview/skins/xui/en-us/panel_region_debug.xml | 8 +- .../skins/xui/en-us/panel_region_estate.xml | 261 +- .../skins/xui/en-us/panel_region_general.xml | 49 +- .../skins/xui/en-us/panel_region_terrain.xml | 32 +- .../skins/xui/en-us/panel_region_texture.xml | 12 +- .../newview/skins/xui/en-us/teleport_strings.xml | 3 + linden/indra/newview/skins/xui/ja/alerts.xml | 1392 +++--- .../indra/newview/skins/xui/ja/floater_about.xml | 15 +- .../newview/skins/xui/ja/floater_about_land.xml | 100 +- .../skins/xui/ja/floater_active_speakers.xml | 11 + .../skins/xui/ja/floater_animation_preview.xml | 13 + .../newview/skins/xui/ja/floater_audio_volume.xml | 4 + .../newview/skins/xui/ja/floater_avatar_picker.xml | 3 + .../newview/skins/xui/ja/floater_buy_contents.xml | 9 + .../newview/skins/xui/ja/floater_buy_currency.xml | 3 + .../newview/skins/xui/ja/floater_buy_land.xml | 6 + .../newview/skins/xui/ja/floater_buy_object.xml | 12 + .../newview/skins/xui/ja/floater_chatterbox.xml | 2 + .../skins/xui/ja/floater_device_settings.xml | 2 + .../newview/skins/xui/ja/floater_directory.xml | 1 + .../indra/newview/skins/xui/ja/floater_friends.xml | 9 +- .../indra/newview/skins/xui/ja/floater_groups.xml | 4 +- .../newview/skins/xui/ja/floater_image_preview.xml | 10 +- .../indra/newview/skins/xui/ja/floater_inspect.xml | 14 + .../skins/xui/ja/floater_instant_message.xml | 7 + .../xui/ja/floater_instant_message_ad_hoc.xml | 43 + .../skins/xui/ja/floater_instant_message_group.xml | 44 + .../newview/skins/xui/ja/floater_inventory.xml | 3 + .../xui/ja/floater_inventory_item_properties.xml | 12 + .../newview/skins/xui/ja/floater_joystick.xml | 13 + .../skins/xui/ja/floater_live_lsleditor.xml | 3 + .../newview/skins/xui/ja/floater_lsl_guide.xml | 7 + linden/indra/newview/skins/xui/ja/floater_mute.xml | 5 +- .../newview/skins/xui/ja/floater_my_friends.xml | 7 + .../newview/skins/xui/ja/floater_postcard.xml | 10 + .../newview/skins/xui/ja/floater_preferences.xml | 6 +- .../skins/xui/ja/floater_preview_notecard.xml | 8 +- .../ja/floater_preview_notecard_keep_discard.xml | 3 + .../skins/xui/ja/floater_script_ed_panel.xml | 15 +- .../newview/skins/xui/ja/floater_select_key.xml | 7 + .../skins/xui/ja/floater_sim_release_message.xml | 16 + .../newview/skins/xui/ja/floater_snapshot.xml | 14 +- linden/indra/newview/skins/xui/ja/floater_test.xml | 2 + .../newview/skins/xui/ja/floater_texture_ctrl.xml | 6 +- .../indra/newview/skins/xui/ja/floater_tools.xml | 30 +- .../newview/skins/xui/ja/floater_voice_wizard.xml | 9 + .../indra/newview/skins/xui/ja/menu_pie_avatar.xml | 1 + linden/indra/newview/skins/xui/ja/menu_viewer.xml | 13 +- linden/indra/newview/skins/xui/ja/need_to_long.xml | 928 ++++ .../newview/skins/xui/ja/need_to_translate.xml | 3700 +++++++++++++++- .../indra/newview/skins/xui/ja/need_to_update.xml | 2713 ++++++++++-- linden/indra/newview/skins/xui/ja/notify.xml | 157 +- linden/indra/newview/skins/xui/ja/panel_audio.xml | 11 + .../newview/skins/xui/ja/panel_audio_device.xml | 20 + linden/indra/newview/skins/xui/ja/panel_avatar.xml | 12 +- .../newview/skins/xui/ja/panel_classified.xml | 6 + linden/indra/newview/skins/xui/ja/panel_event.xml | 15 + .../indra/newview/skins/xui/ja/panel_friends.xml | 34 + linden/indra/newview/skins/xui/ja/panel_group.xml | 2 +- .../newview/skins/xui/ja/panel_group_general.xml | 10 +- .../newview/skins/xui/ja/panel_group_invite.xml | 3 + .../skins/xui/ja/panel_group_land_money.xml | 9 +- .../newview/skins/xui/ja/panel_group_voting.xml | 34 +- linden/indra/newview/skins/xui/ja/panel_groups.xml | 16 + linden/indra/newview/skins/xui/ja/panel_login.xml | 3 + .../newview/skins/xui/ja/panel_master_volume.xml | 7 + .../newview/skins/xui/ja/panel_media_remote.xml | 5 + .../newview/skins/xui/ja/panel_music_remote.xml | 5 + linden/indra/newview/skins/xui/ja/panel_place.xml | 12 + .../skins/xui/ja/panel_preferences_audio.xml | 8 +- .../skins/xui/ja/panel_preferences_chat.xml | 4 +- .../skins/xui/ja/panel_preferences_graphics2.xml | 2 + .../skins/xui/ja/panel_preferences_graphics3.xml | 5 + .../newview/skins/xui/ja/panel_preferences_im.xml | 8 +- .../skins/xui/ja/panel_preferences_popups.xml | 14 +- .../skins/xui/ja/panel_preferences_voice.xml | 39 + .../newview/skins/xui/ja/panel_preferences_web.xml | 12 + .../newview/skins/xui/ja/panel_region_debug.xml | 7 +- .../newview/skins/xui/ja/panel_region_estate.xml | 5 +- .../newview/skins/xui/ja/panel_region_general.xml | 5 +- .../newview/skins/xui/ja/panel_status_bar.xml | 9 +- .../indra/newview/skins/xui/ja/panel_toolbar.xml | 2 + .../newview/skins/xui/ja/panel_voice_enable.xml | 23 + .../newview/skins/xui/ja/panel_voice_options.xml | 23 + .../newview/skins/xui/ja/panel_voice_remote.xml | 8 + .../newview/skins/xui/ja/teleport_strings.xml | 87 + linden/indra/newview/skins/xui/ko/alerts.xml | 270 +- .../indra/newview/skins/xui/ko/floater_about.xml | 13 +- .../newview/skins/xui/ko/floater_about_land.xml | 117 +- .../skins/xui/ko/floater_active_speakers.xml | 11 + .../skins/xui/ko/floater_animation_preview.xml | 21 +- .../newview/skins/xui/ko/floater_audio_volume.xml | 4 + .../skins/xui/ko/floater_avatar_textures.xml | 6 +- .../newview/skins/xui/ko/floater_buy_contents.xml | 9 + .../newview/skins/xui/ko/floater_buy_currency.xml | 3 + .../newview/skins/xui/ko/floater_buy_land.xml | 6 + .../newview/skins/xui/ko/floater_buy_object.xml | 12 + .../newview/skins/xui/ko/floater_chatterbox.xml | 2 + .../newview/skins/xui/ko/floater_customize.xml | 2 +- .../skins/xui/ko/floater_device_settings.xml | 2 + .../newview/skins/xui/ko/floater_directory.xml | 9 +- .../indra/newview/skins/xui/ko/floater_friends.xml | 19 +- .../newview/skins/xui/ko/floater_group_info.xml | 4 +- .../indra/newview/skins/xui/ko/floater_groups.xml | 1 + .../newview/skins/xui/ko/floater_image_preview.xml | 7 +- .../skins/xui/ko/floater_instant_message.xml | 7 + .../xui/ko/floater_instant_message_ad_hoc.xml | 44 + .../skins/xui/ko/floater_instant_message_group.xml | 45 + .../newview/skins/xui/ko/floater_inventory.xml | 4 +- .../xui/ko/floater_inventory_item_properties.xml | 12 + .../skins/xui/ko/floater_live_lsleditor.xml | 3 + .../newview/skins/xui/ko/floater_my_friends.xml | 7 + .../skins/xui/ko/floater_new_outfit_dialog.xml | 2 +- .../newview/skins/xui/ko/floater_postcard.xml | 10 + .../skins/xui/ko/floater_preview_gesture.xml | 4 +- .../skins/xui/ko/floater_preview_notecard.xml | 8 +- .../ko/floater_preview_notecard_keep_discard.xml | 3 + .../newview/skins/xui/ko/floater_report_abuse.xml | 2 +- .../newview/skins/xui/ko/floater_report_bug.xml | 3 +- .../skins/xui/ko/floater_script_ed_panel.xml | 15 +- .../newview/skins/xui/ko/floater_select_key.xml | 7 + .../skins/xui/ko/floater_sim_release_message.xml | 16 + .../newview/skins/xui/ko/floater_snapshot.xml | 5 +- .../indra/newview/skins/xui/ko/floater_telehub.xml | 6 +- linden/indra/newview/skins/xui/ko/floater_test.xml | 2 + .../newview/skins/xui/ko/floater_texture_ctrl.xml | 6 +- .../indra/newview/skins/xui/ko/floater_tools.xml | 22 + .../newview/skins/xui/ko/floater_voice_wizard.xml | 9 + .../newview/skins/xui/ko/floater_world_map.xml | 2 +- .../indra/newview/skins/xui/ko/menu_inventory.xml | 2 +- .../indra/newview/skins/xui/ko/menu_pie_avatar.xml | 1 + linden/indra/newview/skins/xui/ko/menu_viewer.xml | 17 +- linden/indra/newview/skins/xui/ko/need_to_long.xml | 344 ++ .../newview/skins/xui/ko/need_to_translate.xml | 2916 +++++++++++-- .../indra/newview/skins/xui/ko/need_to_update.xml | 4482 ++------------------ linden/indra/newview/skins/xui/ko/notify.xml | 151 +- linden/indra/newview/skins/xui/ko/panel_audio.xml | 11 + .../newview/skins/xui/ko/panel_audio_device.xml | 20 + linden/indra/newview/skins/xui/ko/panel_avatar.xml | 13 +- .../newview/skins/xui/ko/panel_classified.xml | 6 + linden/indra/newview/skins/xui/ko/panel_event.xml | 15 + .../indra/newview/skins/xui/ko/panel_friends.xml | 33 + .../newview/skins/xui/ko/panel_group_general.xml | 10 +- .../newview/skins/xui/ko/panel_group_invite.xml | 3 + .../skins/xui/ko/panel_group_land_money.xml | 9 +- .../newview/skins/xui/ko/panel_group_roles.xml | 2 +- .../newview/skins/xui/ko/panel_group_voting.xml | 40 +- linden/indra/newview/skins/xui/ko/panel_groups.xml | 15 + .../newview/skins/xui/ko/panel_land_covenant.xml | 4 +- linden/indra/newview/skins/xui/ko/panel_login.xml | 9 +- .../newview/skins/xui/ko/panel_master_volume.xml | 7 + .../newview/skins/xui/ko/panel_media_remote.xml | 3 + .../newview/skins/xui/ko/panel_music_remote.xml | 3 + linden/indra/newview/skins/xui/ko/panel_place.xml | 12 + .../skins/xui/ko/panel_preferences_audio.xml | 12 +- .../skins/xui/ko/panel_preferences_chat.xml | 18 +- .../skins/xui/ko/panel_preferences_general.xml | 8 +- .../skins/xui/ko/panel_preferences_graphics2.xml | 14 +- .../skins/xui/ko/panel_preferences_graphics3.xml | 6 +- .../newview/skins/xui/ko/panel_preferences_im.xml | 11 +- .../skins/xui/ko/panel_preferences_input.xml | 4 +- .../skins/xui/ko/panel_preferences_network.xml | 2 +- .../skins/xui/ko/panel_preferences_popups.xml | 16 +- .../skins/xui/ko/panel_preferences_voice.xml | 35 + .../newview/skins/xui/ko/panel_preferences_web.xml | 12 + .../newview/skins/xui/ko/panel_region_debug.xml | 9 +- .../newview/skins/xui/ko/panel_region_estate.xml | 2 + .../newview/skins/xui/ko/panel_region_general.xml | 7 +- .../newview/skins/xui/ko/panel_region_terrain.xml | 2 +- .../newview/skins/xui/ko/panel_status_bar.xml | 7 + .../indra/newview/skins/xui/ko/panel_toolbar.xml | 2 + .../newview/skins/xui/ko/panel_voice_enable.xml | 23 + .../newview/skins/xui/ko/panel_voice_options.xml | 21 + .../newview/skins/xui/ko/panel_voice_remote.xml | 9 + .../newview/skins/xui/ko/teleport_strings.xml | 86 + linden/indra/newview/viewer.cpp | 488 +-- linden/indra/newview/viewer.h | 40 +- linden/indra/newview/viewer_manifest.py | 21 +- linden/indra/test/common.cpp | 3 + linden/indra/test/inventory.cpp | 3 + linden/indra/test/io.cpp | 3 + linden/indra/test/llapp_tut.cpp | 3 + linden/indra/test/llbase64_tut.cpp | 5 +- linden/indra/test/llbitpack_tut.cpp | 5 +- linden/indra/test/llblowfish_tut.cpp | 7 +- linden/indra/test/llbuffer_tut.cpp | 6 +- linden/indra/test/lldatapacker_tut.cpp | 5 +- linden/indra/test/lldate_tut.cpp | 10 +- linden/indra/test/llerror_tut.cpp | 5 + linden/indra/test/llhost_tut.cpp | 7 +- linden/indra/test/llhttpclient_tut.cpp | 3 + linden/indra/test/llhttpdate_tut.cpp | 8 +- linden/indra/test/llhttpnode_tut.cpp | 6 +- linden/indra/test/llinventoryparcel_tut.cpp | 5 +- linden/indra/test/lliohttpserver_tut.cpp | 6 +- linden/indra/test/lljoint_tut.cpp | 5 +- linden/indra/test/llmessageconfig_tut.cpp | 42 +- linden/indra/test/llmessagetemplateparser_tut.cpp | 6 +- linden/indra/test/llmime_tut.cpp | 3 + linden/indra/test/llnamevalue_tut.cpp | 7 +- linden/indra/test/llpartdata_tut.cpp | 5 +- linden/indra/test/llpermissions_tut.cpp | 5 +- linden/indra/test/llpipeutil.cpp | 3 + linden/indra/test/llpipeutil.h | 3 + linden/indra/test/llquaternion_tut.cpp | 22 +- linden/indra/test/llrandom_tut.cpp | 5 +- linden/indra/test/llsaleinfo_tut.cpp | 7 +- linden/indra/test/llsd_new_tut.cpp | 4 +- linden/indra/test/llsdmessagebuilder_tut.cpp | 6 +- linden/indra/test/llsdmessagereader_tut.cpp | 3 + linden/indra/test/llsdserialize_tut.cpp | 6 +- linden/indra/test/llsdtraits.h | 5 +- linden/indra/test/llsdutil_tut.cpp | 5 +- linden/indra/test/llservicebuilder_tut.cpp | 46 +- linden/indra/test/llstreamtools_tut.cpp | 8 +- linden/indra/test/llstring_tut.cpp | 5 +- linden/indra/test/lltemplatemessagebuilder_tut.cpp | 5 +- linden/indra/test/lltiming_tut.cpp | 3 + linden/indra/test/lltut.cpp | 3 + linden/indra/test/lltut.h | 3 + linden/indra/test/lluri_tut.cpp | 6 +- linden/indra/test/lluserrelations_tut.cpp | 3 + linden/indra/test/lluuidhashmap_tut.cpp | 5 +- linden/indra/test/llxfer_tut.cpp | 5 +- linden/indra/test/llxorcipher_tut.cpp | 7 +- linden/indra/test/m3math_tut.cpp | 5 +- linden/indra/test/math.cpp | 3 + linden/indra/test/message_tut.cpp | 5 +- linden/indra/test/reflection_tut.cpp | 4 + linden/indra/test/test.cpp | 3 + linden/indra/test/test.vcproj | 6 +- linden/indra/test/test_llmanifest.py | 57 +- linden/indra/test/v2math_tut.cpp | 19 +- linden/indra/test/v3color_tut.cpp | 12 +- linden/indra/test/v3dmath_tut.cpp | 14 +- linden/indra/test/v3math_tut.cpp | 23 +- linden/indra/test/v4color_tut.cpp | 12 +- linden/indra/test/v4coloru_tut.cpp | 7 +- linden/indra/test/v4math_tut.cpp | 7 +- linden/indra/test/xform_tut.cpp | 7 +- linden/indra/win_crash_logger/StdAfx.cpp | 3 + linden/indra/win_crash_logger/StdAfx.h | 3 + linden/indra/win_crash_logger/win_crash_logger.cpp | 6 +- linden/indra/win_crash_logger/win_crash_logger.h | 3 + .../indra/win_crash_logger/win_crash_logger.vcproj | 6 +- .../win_crash_logger/win_crash_logger_vc8.vcproj | 6 +- linden/indra/win_updater/updater.cpp | 10 +- linden/libraries/include/llmozlib.h | 3 + linden/scripts/messages/message_template.msg | 27 +- linden/scripts/setup-path.py | 57 +- linden/scripts/template_verifier.py | 55 +- 1919 files changed, 40918 insertions(+), 18816 deletions(-) create mode 100644 linden/indra/lib/python/indra/base/__init__.py create mode 100644 linden/indra/lib/python/indra/base/config.py create mode 100644 linden/indra/lib/python/indra/base/llsd.py create mode 100644 linden/indra/lib/python/indra/base/lluuid.py create mode 100644 linden/indra/lib/python/indra/ipc/httputil.py create mode 100644 linden/indra/lib/python/indra/ipc/llsdhttp.py create mode 100644 linden/indra/lib/python/indra/ipc/mysql_pool.py create mode 100644 linden/indra/lib/python/indra/ipc/russ.py create mode 100644 linden/indra/lib/python/indra/ipc/saranwrap.py create mode 100644 linden/indra/lib/python/indra/ipc/servicebuilder.py create mode 100644 linden/indra/lib/python/indra/ipc/webdav.py create mode 100644 linden/indra/lib/python/indra/ipc/xml_rpc.py create mode 100644 linden/indra/lib/python/indra/util/helpformatter.py create mode 100644 linden/indra/lib/python/indra/util/llversion.py create mode 100644 linden/indra/lib/python/indra/util/named_query.py create mode 100644 linden/indra/llcommon/llares.cpp create mode 100644 linden/indra/llcommon/llares.h delete mode 100644 linden/indra/newview/llasynchostbyname.cpp delete mode 100644 linden/indra/newview/llasynchostbyname.h create mode 100644 linden/indra/newview/llcommandhandler.cpp create mode 100644 linden/indra/newview/llcommandhandler.h delete mode 100644 linden/indra/newview/llfloaterhtmlfind.cpp delete mode 100644 linden/indra/newview/llfloaterhtmlfind.h create mode 100644 linden/indra/newview/llfloaterlagmeter.cpp create mode 100644 linden/indra/newview/llfloaterlagmeter.h create mode 100644 linden/indra/newview/llurldispatcher.cpp create mode 100644 linden/indra/newview/llurldispatcher.h create mode 100644 linden/indra/newview/llurlsimstring.cpp create mode 100644 linden/indra/newview/llurlsimstring.h create mode 100644 linden/indra/newview/skins/xui/de/floater_active_speakers.xml create mode 100644 linden/indra/newview/skins/xui/de/floater_audio_volume.xml create mode 100644 linden/indra/newview/skins/xui/de/floater_chatterbox.xml create mode 100644 linden/indra/newview/skins/xui/de/floater_device_settings.xml create mode 100644 linden/indra/newview/skins/xui/de/floater_instant_message_ad_hoc.xml create mode 100644 linden/indra/newview/skins/xui/de/floater_instant_message_group.xml create mode 100644 linden/indra/newview/skins/xui/de/floater_my_friends.xml create mode 100644 linden/indra/newview/skins/xui/de/floater_select_key.xml create mode 100644 linden/indra/newview/skins/xui/de/floater_sim_release_message.xml create mode 100644 linden/indra/newview/skins/xui/de/floater_test.xml create mode 100644 linden/indra/newview/skins/xui/de/floater_voice_wizard.xml create mode 100644 linden/indra/newview/skins/xui/de/need_to_long.xml create mode 100644 linden/indra/newview/skins/xui/de/panel_audio.xml create mode 100644 linden/indra/newview/skins/xui/de/panel_audio_device.xml create mode 100644 linden/indra/newview/skins/xui/de/panel_friends.xml create mode 100644 linden/indra/newview/skins/xui/de/panel_groups.xml create mode 100644 linden/indra/newview/skins/xui/de/panel_master_volume.xml create mode 100644 linden/indra/newview/skins/xui/de/panel_preferences_voice.xml create mode 100644 linden/indra/newview/skins/xui/de/panel_voice_enable.xml create mode 100644 linden/indra/newview/skins/xui/de/panel_voice_options.xml create mode 100644 linden/indra/newview/skins/xui/de/panel_voice_remote.xml create mode 100644 linden/indra/newview/skins/xui/en-us/floater_lagmeter.xml create mode 100644 linden/indra/newview/skins/xui/ja/floater_active_speakers.xml create mode 100644 linden/indra/newview/skins/xui/ja/floater_audio_volume.xml create mode 100644 linden/indra/newview/skins/xui/ja/floater_chatterbox.xml create mode 100644 linden/indra/newview/skins/xui/ja/floater_device_settings.xml create mode 100644 linden/indra/newview/skins/xui/ja/floater_inspect.xml create mode 100644 linden/indra/newview/skins/xui/ja/floater_instant_message_ad_hoc.xml create mode 100644 linden/indra/newview/skins/xui/ja/floater_instant_message_group.xml create mode 100644 linden/indra/newview/skins/xui/ja/floater_joystick.xml create mode 100644 linden/indra/newview/skins/xui/ja/floater_lsl_guide.xml create mode 100644 linden/indra/newview/skins/xui/ja/floater_my_friends.xml create mode 100644 linden/indra/newview/skins/xui/ja/floater_select_key.xml create mode 100644 linden/indra/newview/skins/xui/ja/floater_sim_release_message.xml create mode 100644 linden/indra/newview/skins/xui/ja/floater_test.xml create mode 100644 linden/indra/newview/skins/xui/ja/floater_voice_wizard.xml create mode 100644 linden/indra/newview/skins/xui/ja/need_to_long.xml create mode 100644 linden/indra/newview/skins/xui/ja/panel_audio.xml create mode 100644 linden/indra/newview/skins/xui/ja/panel_audio_device.xml create mode 100644 linden/indra/newview/skins/xui/ja/panel_friends.xml create mode 100644 linden/indra/newview/skins/xui/ja/panel_groups.xml create mode 100644 linden/indra/newview/skins/xui/ja/panel_master_volume.xml create mode 100644 linden/indra/newview/skins/xui/ja/panel_preferences_voice.xml create mode 100644 linden/indra/newview/skins/xui/ja/panel_preferences_web.xml create mode 100644 linden/indra/newview/skins/xui/ja/panel_voice_enable.xml create mode 100644 linden/indra/newview/skins/xui/ja/panel_voice_options.xml create mode 100644 linden/indra/newview/skins/xui/ja/panel_voice_remote.xml create mode 100644 linden/indra/newview/skins/xui/ja/teleport_strings.xml create mode 100644 linden/indra/newview/skins/xui/ko/floater_active_speakers.xml create mode 100644 linden/indra/newview/skins/xui/ko/floater_audio_volume.xml create mode 100644 linden/indra/newview/skins/xui/ko/floater_chatterbox.xml create mode 100644 linden/indra/newview/skins/xui/ko/floater_device_settings.xml create mode 100644 linden/indra/newview/skins/xui/ko/floater_instant_message_ad_hoc.xml create mode 100644 linden/indra/newview/skins/xui/ko/floater_instant_message_group.xml create mode 100644 linden/indra/newview/skins/xui/ko/floater_my_friends.xml create mode 100644 linden/indra/newview/skins/xui/ko/floater_select_key.xml create mode 100644 linden/indra/newview/skins/xui/ko/floater_sim_release_message.xml create mode 100644 linden/indra/newview/skins/xui/ko/floater_test.xml create mode 100644 linden/indra/newview/skins/xui/ko/floater_voice_wizard.xml create mode 100644 linden/indra/newview/skins/xui/ko/need_to_long.xml create mode 100644 linden/indra/newview/skins/xui/ko/panel_audio.xml create mode 100644 linden/indra/newview/skins/xui/ko/panel_audio_device.xml create mode 100644 linden/indra/newview/skins/xui/ko/panel_friends.xml create mode 100644 linden/indra/newview/skins/xui/ko/panel_groups.xml create mode 100644 linden/indra/newview/skins/xui/ko/panel_master_volume.xml create mode 100644 linden/indra/newview/skins/xui/ko/panel_preferences_voice.xml create mode 100644 linden/indra/newview/skins/xui/ko/panel_preferences_web.xml create mode 100644 linden/indra/newview/skins/xui/ko/panel_voice_enable.xml create mode 100644 linden/indra/newview/skins/xui/ko/panel_voice_options.xml create mode 100644 linden/indra/newview/skins/xui/ko/panel_voice_remote.xml create mode 100644 linden/indra/newview/skins/xui/ko/teleport_strings.xml (limited to 'linden') diff --git a/linden/doc/contributions.txt b/linden/doc/contributions.txt index 723a603..2d3fa99 100644 --- a/linden/doc/contributions.txt +++ b/linden/doc/contributions.txt @@ -1,32 +1,49 @@ Linden Lab would like to acknowledge source code contributions from the following residents. The Second Life resident name is given below, along with the issue identifier corresponding to the patches we've -received from them. To see more about these contributions, visit -http://jira.secondlife.com/ and enter the issue identifier. +received from them. To see more about these contributions, visit the +browsable version: http://wiki.secondlife.com/wiki/Source_contributions Able Whitman VWR-650 VWR-1460 + VWR-1691 +Alejandro Rosenthal + VWR-1184 Alissa Sabre VWR-81 VWR-83 + VWR-109 + VWR-157 VWR-171 + VWR-177 + VWR-213 VWR-251 + VWR-286 VWR-414 VWR-415 VWR-459 VWR-606 VWR-652 + VWR-738 + VWR-1109 VWR-1351 + VWR-1353 VWR-1410 + VWR-2116 Argent Stonecutter VWR-68 Benja Kepler VWR-746 Blakar Ogre VWR-881 + VWR-1612 + VWR-1613 blino Nakamura VWR-17 +Boroondas Gupte + VWR-233 + WEB-262 bushing Spatula VWR-119 VWR-424 @@ -35,16 +52,25 @@ Catherine Pfeffer Dale Glass VWR-120 VWR-560 + VWR-1358 + VWR-2041 Drewan Keats VWR-28 VWR-248 VWR-412 + VWR-638 + VWR-660 Dylan Haskell VWR-72 Dzonatas Sol + VWR-187 VWR-198 + VWR-777 VWR-878 + VWR-962 VWR-975 + VWR-1061 + VWR-1062 VWR-1704 VWR-1705 VWR-1729 @@ -53,28 +79,45 @@ Eddy Stryker VWR-23 VWR-1468 EponymousDylan Ra + VWR-1289 VWR-1465 +Farallon Greyskin + VWR-2036 Feep Larsson + VWR-447 VWR-1314 Fremont Cunningham VWR-1147 Gigs Taggart + SVC-493 + VWR-38 VWR-71 + VWR-101 + VWR-166 + VWR-234 + VWR-315 VWR-326 VWR-493 + VWR-1203 VWR-1217 VWR-1434 VWR-1987 + VWR-2065 Ginko Bayliss VWR-4 Grazer Kline VWR-1092 Gudmund Shepherd VWR-1594 +Hamncheese Omlet + VWR-333 +Henri Beauchamp + VWR-1406 Hikkoshi Sakai VWR-429 Hiro Sommambulist VWR-66 + VWR-67 VWR-97 VWR-100 VWR-105 @@ -83,6 +126,8 @@ Hiro Sommambulist VWR-132 VWR-136 VWR-143 +Hoze Menges + VWR-255 Iskar Ariantho VWR-1223 Jacek Antonelli @@ -96,9 +141,11 @@ Kage Pixel VWR-11 Kunnis Basiat VWR-82 + VWR-102 Matthew Dowd VWR-1344 VWR-1736 + VWR-1737 VWR-1761 McCabe Maxsted VWR-1318 @@ -107,38 +154,51 @@ Mr Greggan Nicholaz Beresford VWR-132 VWR-176 + VWR-193 + VWR-349 + VWR-353 VWR-364 VWR-546 VWR-691 + VWR-727 VWR-793 VWR-794 VWR-802 VWR-803 VWR-804 VWR-805 + VWR-807 VWR-808 VWR-809 VWR-810 VWR-823 + VWR-849 VWR-856 + VWR-865 VWR-869 VWR-870 VWR-871 VWR-873 VWR-908 VWR-966 + VWR-1105 VWR-1221 VWR-1230 VWR-1270 + VWR-1294 VWR-1296 + VWR-1354 VWR-1410 VWR-1418 + VWR-1436 VWR-1453 VWR-1455 VWR-1470 + VWR-1471 VWR-1566 VWR-1578 VWR-1626 + VWR-1646 VWR-1655 VWR-1698 VWR-1706 @@ -151,6 +211,8 @@ Nicholaz Beresford VWR-1872 VWR-1968 VWR-2152 +Nounouch Hapmouche + VWR-238 Paul Churchill VWR-20 VWR-493 @@ -160,7 +222,9 @@ Paul Churchill VWR-1880 Paula Innis VWR-30 + VWR-293 VWR-1049 + VWR-1562 Peekay Semyorka VWR-7 VWR-19 @@ -170,27 +234,42 @@ Renault Clio VWR-1976 Ryozu Kojima VWR-287 +Seg Baphomet + VWR-1525 + VWR-1585 + VWR-1586 SignpostMarv Martin + VWR-153 VWR-154 VWR-155 + VWR-218 + VWR-373 Simon Nolan VWR-409 SpacedOut Frye + VWR-34 + VWR-45 VWR-57 VWR-94 + VWR-113 VWR-121 VWR-123 + VWR-130 VWR-1823 Stevex Janus VWR-1182 Still Defiant VWR-207 + VWR-227 VWR-446 Strife Onizuka SVC-9 + VWR-14 VWR-74 VWR-85 VWR-148 + WEB-164 + VWR-183 VWR-2265 tenebrous pau VWR-247 @@ -200,6 +279,7 @@ TBBle Kurosawa VWR-942 VWR-944 VWR-945 + VWR-1891 VWR-1892 Tharax Ferraris VWR-605 @@ -207,10 +287,14 @@ Thraxis Epsilon SVC-371 VWR-383 Whoops Babii + VWR-631 VWR-1640 +Zarkonnen Decosta + VWR-253 Zi Ree VWR-671 VWR-682 + VWR-684 VWR-1140 Zipherius Turas VWR-76 diff --git a/linden/etc/message.xml b/linden/etc/message.xml index 304ba32..614d2b0 100644 --- a/linden/etc/message.xml +++ b/linden/etc/message.xml @@ -255,7 +255,7 @@ CoarseLocationUpdate flavor - template + llsd trusted-sender true @@ -276,6 +276,14 @@ true + AgentGroupDataUpdate + + flavor + llsd + trusted-sender + true + + ChatterBoxSessionStartReply flavor diff --git a/linden/indra/SConstruct b/linden/indra/SConstruct index 9298f7a..f1a6c89 100644 --- a/linden/indra/SConstruct +++ b/linden/indra/SConstruct @@ -25,10 +25,11 @@ ################################################# -import os -import sys import glob +import os +import random import re +import sys platform = sys.platform if platform == 'linux2': @@ -91,8 +92,8 @@ opts.AddOptions( BoolOption('COLORGCC', 'Enabled colorgcc', True), EnumOption('GRID', 'Client package\'s default grid', 'default', allowed_values=('default', 'aditi', 'agni', 'dmz', 'durga', 'ganga', 'shakti', 'siva', 'soma', 'uma', 'vaak')), - EnumOption('CHANNEL', 'Client package\'s default channel', 'default', - allowed_values=('default', 'Release', 'Release Candidate', 'WindLight')), + EnumOption('CHANNEL', 'Client package\'s default channel', 'Release', + allowed_values=('Release', 'Release Candidate', 'WindLight')), BoolOption('ELFIO', 'Enabled enhanced backtraces with libELFIO symbol extraction support', True), BoolOption('STANDALONE', 'Build using system packages (implies OPENSOURCE)', False), BoolOption('OPENSOURCE', 'Build using only non-proprietary dependencies', True) # OPENSOURCE: do not edit this line @@ -211,20 +212,7 @@ for build_target in targets: """ + '../libraries/' + system_str + '/include' ) - if platform == 'linux' and build_target == 'client': - if standalone: - if arch == 'x86_64' and os.path.exists('/usr/lib64'): - client_external_libs = [File('/usr/lib64/libresolv.a')] - else: - client_external_libs = [File('/usr/lib/libresolv.a')] - else: - # Custom libresolv build which avoids a billion flavors of - # brokenness prevalent in common libresolvs out there. - client_external_libs = ['resolv'] - include_dirs += ['../libraries/' + system_str + '/include/llresolv8'] - else: - client_external_libs = ['resolv'] - + client_external_libs = [] system_link_flags = '' if platform != 'linux' and build_target == 'client' and enable_mozlib: @@ -255,7 +243,7 @@ for build_target in targets: ############## # Generic GCC flags - cflags = '-g -pipe -Wall -Wno-reorder -Wno-trigraphs -Wno-sign-compare -Werror ' + cflags = '-g -pipe -Wall -Wno-reorder -Wno-trigraphs -Wno-sign-compare -Werror -fexceptions ' cxxflags = '' cppflags = '-D_FORTIFY_SOURCE=2 ' if standalone: @@ -276,7 +264,7 @@ for build_target in targets: cppflags += server_cppflags + ' ' else: # Viewer flags - cflags += '-pthread -D_REENTRANT -fno-math-errno -fexceptions -fsigned-char -fno-strict-aliasing ' + cflags += '-pthread -D_REENTRANT -fno-math-errno -fsigned-char -fno-strict-aliasing ' cppflags += '-DLL_MESA_HEADLESS=0 -DLL_MESA=0 ' try: client_cppflags = os.environ['CLIENT_CPPFLAGS'] @@ -327,7 +315,7 @@ for build_target in targets: cppflags += '-DLL_GSTREAMER_ENABLED=0 ' else: # Mac-only flags - cflags += '-x c++ -arch ppc -pipe -Wno-trigraphs -fpascal-strings -faltivec -fasm-blocks -g -fmessage-length=0 -mtune=G4 -Wno-deprecated-declarations -Wno-invalid-offsetof -mmacosx-version-min=10.3 -Wmost -Wno-sign-compare -Wno-switch -fconstant-cfstrings -ffor-scope -Wno-reorder ' + cflags += '-x c++ -arch ppc -pipe -Wno-trigraphs -fpascal-strings -faltivec -fasm-blocks -g -fmessage-length=0 -mtune=G4 -Wno-deprecated-declarations -Wno-invalid-offsetof -mmacosx-version-min=10.3 -Wmost -Wno-sign-compare -Wno-switch -fconstant-cfstrings -ffor-scope -Wno-reorder -fexceptions ' cppflags += '-x c++ -DLL_DARWIN=1 -fpch-preprocess -F./newview/build/Deployment -fconstant-cfstrings -isysroot /Developer/SDKs/MacOSX10.3.9.sdk ' if standalone: @@ -447,9 +435,13 @@ for build_target in targets: ### Distributed build hosts ### if enable_distcc: - hosts = 'localhost/2 station9.lindenlab.com,lzo station7.lindenlab.com,lzo station6.lindenlab.com,lzo station11.lindenlab.com,lzo station5.lindenlab.com,lzo station15.lindenlab.com,lzo station10.lindenlab.com,lzo station13.lindenlab.com,lzo station12.lindenlab.com,lzo' - if arch == 'x86_64' or arch == 'x86_64cross': - hosts = 'localhost' + hosts = [ 'localhost/2', ] + if arch == 'i686': + dead = [] + stations = [s for s in xrange(36) if s not in dead] + random.shuffle(stations) + hosts += ['station%d.lindenlab.com/2,lzo' % s for s in stations] + hosts = ' '.join(hosts) print "Distributing to hosts: " + hosts env['ENV']['DISTCC_HOSTS'] = hosts env['ENV']['USER'] = os.environ['USER'] @@ -624,7 +616,6 @@ for build_target in targets: pkgconfig('--libs-only-l', ['gtk+-2.0']).split()] else: external_libs = net_external_libs + [ 'db-4.2', 'gtk-x11-2.0' ] - external_libs.remove('cares') internal_libs = [ 'llvfs', 'llmath', 'llcommon' ] create_executable(output_crashlogger_bin + '-globalsyms', 'linux_crash_logger', @@ -649,8 +640,8 @@ for build_target in targets: external_libs += [ d[2:] for d in pkgconfig('--libs-only-l').split() ] else: - external_libs += [ 'freetype', 'SDL', 'ogg', 'vorbisenc', - 'vorbisfile', 'vorbis', 'db-4.2' ] + external_libs += [ 'freetype', 'SDL', 'vorbisenc', + 'vorbisfile', 'vorbis', 'ogg', 'db-4.2' ] external_libs += [ 'jpeg', 'openjpeg', 'png12', 'GL', 'GLU' ] @@ -660,8 +651,6 @@ for build_target in targets: if buildtype == 'debug': external_libs += ['tcmalloc', 'stacktrace'] - external_libs.remove('cares') - internal_libs = [ 'lscript', 'llwindow', 'llrender', 'llprimitive', 'llmedia', 'llinventory', 'llimage', 'llimagej2coj', @@ -684,7 +673,7 @@ for build_target in targets: product_name = 'SecondLife_' + arch + '_' + "_".join(version_viewer.split(".")) if grid not in ['default', 'agni']: product_name += "_" + grid.upper() - if channel not in ['default', 'Release']: + if channel not in ['Release']: product_name += "_" + "".join((channel.upper()).split()) package_name = product_name + '.tar.bz2' complete_channel = 'Second Life ' + channel @@ -701,7 +690,7 @@ for build_target in targets: elif build_target == 'server': create_static_module('lldatabase') create_static_module('llscene') - create_static_module('llhavok', '-fno-exceptions -fno-rtti') + create_static_module('llhavok', '-fno-rtti') create_static_module_from_dir('llkdu', 'llkdustatic') diff --git a/linden/indra/indra_complete/indra_complete.sln b/linden/indra/indra_complete/indra_complete.sln index 76346f9..70bcbbd 100644 --- a/linden/indra/indra_complete/indra_complete.sln +++ b/linden/indra/indra_complete/indra_complete.sln @@ -170,20 +170,6 @@ EndProject {7BCB4B2C-8378-4186-88EA-5742B5ABE17F} = {7BCB4B2C-8378-4186-88EA-5742B5ABE17F} EndProjectSection EndProject - ProjectSection(ProjectDependencies) = postProject - {2ADE3C14-94C4-40BF-B033-70F3C954EE90} = {2ADE3C14-94C4-40BF-B033-70F3C954EE90} - {B5B53617-416F-404A-BF10-22EBCCA0E4FB} = {B5B53617-416F-404A-BF10-22EBCCA0E4FB} - {AF2D801E-EEE7-4B52-A025-F8E648ADC34B} = {AF2D801E-EEE7-4B52-A025-F8E648ADC34B} - {93B2BA29-FBE9-4376-92C1-6108DCFE09D3} = {93B2BA29-FBE9-4376-92C1-6108DCFE09D3} - {7BCB4B2C-8378-4186-88EA-5742B5ABE17F} = {7BCB4B2C-8378-4186-88EA-5742B5ABE17F} - {DE55D666-6A3D-476C-937F-109269B83681} = {DE55D666-6A3D-476C-937F-109269B83681} - {681FDD6C-2FAE-4CB9-AF6D-B952F2B151C5} = {681FDD6C-2FAE-4CB9-AF6D-B952F2B151C5} - {E5D94794-5671-4BD6-A16D-26EC18F3DB34} = {E5D94794-5671-4BD6-A16D-26EC18F3DB34} - {A5470DA6-0C3A-4602-B930-43DB25511A59} = {A5470DA6-0C3A-4602-B930-43DB25511A59} - {E87FD9BE-BE42-4EA3-BF4D-D992223046D9} = {E87FD9BE-BE42-4EA3-BF4D-D992223046D9} - {D37774F4-253D-4760-BF64-372A943224A1} = {D37774F4-253D-4760-BF64-372A943224A1} - EndProjectSection -EndProject Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "llmedia", "..\llmedia\llmedia.vcproj", "{9D0C7E02-6506-4EE7-BC5C-75671D28D594}" ProjectSection(ProjectDependencies) = postProject EndProjectSection @@ -249,12 +235,52 @@ Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "llimagej2coj", "..\llimagej ProjectSection(ProjectDependencies) = postProject EndProjectSection EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "build_all", "build_all.vcproj", "{D2CE3C3B-714F-42C4-BDEC-EDB62528E1BE}" + ProjectSection(ProjectDependencies) = postProject + {9D0C7E02-6506-4EE7-BC5C-75671D28D594} = {9D0C7E02-6506-4EE7-BC5C-75671D28D594} + {2ADE3C14-94C4-40BF-B033-70F3C954EE90} = {2ADE3C14-94C4-40BF-B033-70F3C954EE90} + {B5B53617-416F-404A-BF10-22EBCCA0E4FB} = {B5B53617-416F-404A-BF10-22EBCCA0E4FB} + {E6F4CF1B-6109-4CA8-B58D-87FA936CDE08} = {E6F4CF1B-6109-4CA8-B58D-87FA936CDE08} + {A5504A1E-8BA4-45D2-8144-1B6937E37E98} = {A5504A1E-8BA4-45D2-8144-1B6937E37E98} + {AF2D801E-EEE7-4B52-A025-F8E648ADC34B} = {AF2D801E-EEE7-4B52-A025-F8E648ADC34B} + {93B2BA29-FBE9-4376-92C1-6108DCFE09D3} = {93B2BA29-FBE9-4376-92C1-6108DCFE09D3} + {7BCB4B2C-8378-4186-88EA-5742B5ABE17F} = {7BCB4B2C-8378-4186-88EA-5742B5ABE17F} + {E928F33B-E090-4FA8-818B-6B5D8B0F1F4B} = {E928F33B-E090-4FA8-818B-6B5D8B0F1F4B} + {FCC4483C-5B84-4944-B91F-4589A219BC0B} = {FCC4483C-5B84-4944-B91F-4589A219BC0B} + {F882263E-4F2A-43D9-A45A-FA4C8EC66552} = {F882263E-4F2A-43D9-A45A-FA4C8EC66552} + {076DD042-2E58-42EA-9401-53210B65C1FC} = {076DD042-2E58-42EA-9401-53210B65C1FC} + {6AEE004D-BFE8-4082-B4D3-E51163B01EEB} = {6AEE004D-BFE8-4082-B4D3-E51163B01EEB} + {4B19F64E-AB97-4FB9-8E1D-74A8104DE0C4} = {4B19F64E-AB97-4FB9-8E1D-74A8104DE0C4} + {E9F5BD55-F8E8-4C61-B9B5-CCE7C1048241} = {E9F5BD55-F8E8-4C61-B9B5-CCE7C1048241} + {F56CA265-93E9-4068-8A67-8B104C876D70} = {F56CA265-93E9-4068-8A67-8B104C876D70} + {DE55D666-6A3D-476C-937F-109269B83681} = {DE55D666-6A3D-476C-937F-109269B83681} + {328D1968-924F-4863-AAE8-5F9A95BA68E5} = {328D1968-924F-4863-AAE8-5F9A95BA68E5} + {681FDD6C-2FAE-4CB9-AF6D-B952F2B151C5} = {681FDD6C-2FAE-4CB9-AF6D-B952F2B151C5} + {B771CF1B-E253-47BD-8B0A-6B0440CC9228} = {B771CF1B-E253-47BD-8B0A-6B0440CC9228} + {44CE6D82-7320-4609-8FC3-5965C19F4808} = {44CE6D82-7320-4609-8FC3-5965C19F4808} + {BBAA6588-CA96-4A87-A988-B02270B8D02B} = {BBAA6588-CA96-4A87-A988-B02270B8D02B} + {E5D94794-5671-4BD6-A16D-26EC18F3DB34} = {E5D94794-5671-4BD6-A16D-26EC18F3DB34} + {EC2A989E-3F8F-4B8B-9AE6-7C7EA37C84BC} = {EC2A989E-3F8F-4B8B-9AE6-7C7EA37C84BC} + {A5470DA6-0C3A-4602-B930-43DB25511A59} = {A5470DA6-0C3A-4602-B930-43DB25511A59} + {BFA102B0-C891-4E13-B1CF-C2F28073DA8E} = {BFA102B0-C891-4E13-B1CF-C2F28073DA8E} + {777F38BE-2DFE-4051-9AAD-2832ABC474CC} = {777F38BE-2DFE-4051-9AAD-2832ABC474CC} + {E87FD9BE-BE42-4EA3-BF4D-D992223046D9} = {E87FD9BE-BE42-4EA3-BF4D-D992223046D9} + {D0FDC1C3-A589-40F2-ABCA-A84FF3835624} = {D0FDC1C3-A589-40F2-ABCA-A84FF3835624} + {B4B838C7-2C72-428E-BBFD-25764E659A8B} = {B4B838C7-2C72-428E-BBFD-25764E659A8B} + {4C8D64D5-649F-481E-96BE-EF1E82A77ACB} = {4C8D64D5-649F-481E-96BE-EF1E82A77ACB} + {5EA5DDF0-C7E1-4F49-BEF5-9246A4656B2E} = {5EA5DDF0-C7E1-4F49-BEF5-9246A4656B2E} + {648685F3-8760-4CC5-BB2B-CAF9DECC25A4} = {648685F3-8760-4CC5-BB2B-CAF9DECC25A4} + {D37774F4-253D-4760-BF64-372A943224A1} = {D37774F4-253D-4760-BF64-372A943224A1} + {C6CA76F5-DCB4-4789-BBA7-43D11EE7C8E2} = {C6CA76F5-DCB4-4789-BBA7-43D11EE7C8E2} + {023011F7-3ADB-49D3-9EC5-6D392F6D15FE} = {023011F7-3ADB-49D3-9EC5-6D392F6D15FE} + EndProjectSection +EndProject Global GlobalSection(SolutionConfiguration) = preSolution - ReleaseNoOpt = ReleaseNoOpt - ReleaseForDownload = ReleaseForDownload Debug = Debug Release = Release + ReleaseForDownload = ReleaseForDownload + ReleaseNoOpt = ReleaseNoOpt EndGlobalSection GlobalSection(ProjectDependencies) = postSolution EndGlobalSection @@ -467,13 +493,6 @@ Global {F56CA265-93E9-4068-8A67-8B104C876D70}.Release.ActiveCfg = Release|Win32 {F56CA265-93E9-4068-8A67-8B104C876D70}.ReleaseForDownload.ActiveCfg = Release|Win32 {F56CA265-93E9-4068-8A67-8B104C876D70}.ReleaseNoOpt.ActiveCfg = ReleaseNoOpt|Win32 - {BF69CC7B-5C5B-40C3-93CB-92AD6A5FBC45}.Debug.ActiveCfg = Debug|Win32 - {BF69CC7B-5C5B-40C3-93CB-92AD6A5FBC45}.Debug.Build.0 = Debug|Win32 - {BF69CC7B-5C5B-40C3-93CB-92AD6A5FBC45}.Release.ActiveCfg = Release|Win32 - {BF69CC7B-5C5B-40C3-93CB-92AD6A5FBC45}.Release.Build.0 = Release|Win32 - {BF69CC7B-5C5B-40C3-93CB-92AD6A5FBC45}.ReleaseForDownload.ActiveCfg = Release|Win32 - {BF69CC7B-5C5B-40C3-93CB-92AD6A5FBC45}.ReleaseNoOpt.ActiveCfg = ReleaseNoOpt|Win32 - {BF69CC7B-5C5B-40C3-93CB-92AD6A5FBC45}.ReleaseNoOpt.Build.0 = ReleaseNoOpt|Win32 {9D0C7E02-6506-4EE7-BC5C-75671D28D594}.Debug.ActiveCfg = Debug|Win32 {9D0C7E02-6506-4EE7-BC5C-75671D28D594}.Debug.Build.0 = Debug|Win32 {9D0C7E02-6506-4EE7-BC5C-75671D28D594}.Release.ActiveCfg = Release|Win32 @@ -544,6 +563,14 @@ Global {4C8D64D5-649F-481E-96BE-EF1E82A77ACB}.ReleaseForDownload.Build.0 = Release|Win32 {4C8D64D5-649F-481E-96BE-EF1E82A77ACB}.ReleaseNoOpt.ActiveCfg = ReleaseNoOpt|Win32 {4C8D64D5-649F-481E-96BE-EF1E82A77ACB}.ReleaseNoOpt.Build.0 = ReleaseNoOpt|Win32 + {D2CE3C3B-714F-42C4-BDEC-EDB62528E1BE}.Debug.ActiveCfg = Debug|Win32 + {D2CE3C3B-714F-42C4-BDEC-EDB62528E1BE}.Debug.Build.0 = Debug|Win32 + {D2CE3C3B-714F-42C4-BDEC-EDB62528E1BE}.Release.ActiveCfg = Release|Win32 + {D2CE3C3B-714F-42C4-BDEC-EDB62528E1BE}.Release.Build.0 = Release|Win32 + {D2CE3C3B-714F-42C4-BDEC-EDB62528E1BE}.ReleaseForDownload.ActiveCfg = Release|Win32 + {D2CE3C3B-714F-42C4-BDEC-EDB62528E1BE}.ReleaseForDownload.Build.0 = Release|Win32 + {D2CE3C3B-714F-42C4-BDEC-EDB62528E1BE}.ReleaseNoOpt.ActiveCfg = ReleaseNoOpt|Win32 + {D2CE3C3B-714F-42C4-BDEC-EDB62528E1BE}.ReleaseNoOpt.Build.0 = ReleaseNoOpt|Win32 EndGlobalSection GlobalSection(ExtensibilityGlobals) = postSolution EndGlobalSection diff --git a/linden/indra/lib/python/indra/__init__.py b/linden/indra/lib/python/indra/__init__.py index 220768f..353a93f 100644 --- a/linden/indra/lib/python/indra/__init__.py +++ b/linden/indra/lib/python/indra/__init__.py @@ -2,26 +2,19 @@ @file __init__.py @brief Initialization file for the indra module. +$LicenseInfo:firstyear=2006&license=internal$ + Copyright (c) 2006-2007, Linden Research, Inc. -# Second Life Viewer Source Code -# The source code in this file ("Source Code") is provided by Linden Lab -# to you under the terms of the GNU General Public License, version 2.0 -# ("GPL"), unless you have obtained a separate licensing agreement -# ("Other License"), formally executed by you and Linden Lab. Terms of -# the GPL can be found in doc/GPL-license.txt in this distribution, or -# online at http://secondlife.com/developers/opensource/gplv2 -# -# There are special exceptions to the terms and conditions of the GPL as -# it is applied to this Source Code. View the full text of the exception -# in the file doc/FLOSS-exception.txt in this software distribution, or -# online at http://secondlife.com/developers/opensource/flossexception -# -# By copying, modifying or distributing this software, you acknowledge -# that you have read and understood your obligations described above, -# and agree to abide by those obligations. -# -# ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO -# WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, -# COMPLETENESS OR PERFORMANCE. +The following source code is PROPRIETARY AND CONFIDENTIAL. Use of +this source code is governed by the Linden Lab Source Code Disclosure +Agreement ("Agreement") previously entered between you and Linden +Lab. By accessing, using, copying, modifying or distributing this +software, you acknowledge that you have been informed of your +obligations under the Agreement and agree to abide by those obligations. + +ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO +WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, +COMPLETENESS OR PERFORMANCE. +$/LicenseInfo$ """ diff --git a/linden/indra/lib/python/indra/base/__init__.py b/linden/indra/lib/python/indra/base/__init__.py new file mode 100644 index 0000000..913164d --- /dev/null +++ b/linden/indra/lib/python/indra/base/__init__.py @@ -0,0 +1,27 @@ +"""\ +@file __init__.py +@brief Initialization file for the indra.base module. + +$LicenseInfo:firstyear=2007&license=mit$ + +Copyright (c) 2007, Linden Research, Inc. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. +$/LicenseInfo$ +""" diff --git a/linden/indra/lib/python/indra/base/config.py b/linden/indra/lib/python/indra/base/config.py new file mode 100644 index 0000000..c6872fa --- /dev/null +++ b/linden/indra/lib/python/indra/base/config.py @@ -0,0 +1,74 @@ +"""\ +@file config.py +@brief Utility module for parsing and accessing the indra.xml config file. + +$LicenseInfo:firstyear=2006&license=mit$ + +Copyright (c) 2006-2007, Linden Research, Inc. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. +$/LicenseInfo$ +""" + +from os.path import dirname, join, realpath +import types +from indra.base import llsd + +_g_config_dict = None + +def load(indra_xml_file=None): + global _g_config_dict + if _g_config_dict == None: + if indra_xml_file is None: + ## going from: + ## "/opt/linden/indra/lib/python/indra/base/config.py" + ## to: + ## "/opt/linden/etc/indra.xml" + indra_xml_file = realpath( + dirname(realpath(__file__)) + "../../../../../../etc/indra.xml") + config_file = file(indra_xml_file) + _g_config_dict = llsd.LLSD().parse(config_file.read()) + config_file.close() + #print "loaded config from",indra_xml_file,"into",_g_config_dict + +def update(new_conf): + """Load an XML file and apply its map as overrides or additions + to the existing config. The dataserver does this with indra.xml + and dataserver.xml.""" + global _g_config_dict + if _g_config_dict == None: + _g_config_dict = {} + if isinstance(new_conf, dict): + overrides = new_conf + else: + config_file = file(new_conf) + overrides = llsd.LLSD().parse(config_file.read()) + config_file.close() + + _g_config_dict.update(overrides) + +def get(key, default = None): + global _g_config_dict + if _g_config_dict == None: + load() + return _g_config_dict.get(key, default) + +def as_dict(): + global _g_config_dict + return _g_config_dict diff --git a/linden/indra/lib/python/indra/base/llsd.py b/linden/indra/lib/python/indra/base/llsd.py new file mode 100644 index 0000000..9e636ea --- /dev/null +++ b/linden/indra/lib/python/indra/base/llsd.py @@ -0,0 +1,870 @@ +"""\ +@file llsd.py +@brief Types as well as parsing and formatting functions for handling LLSD. + +$LicenseInfo:firstyear=2006&license=mit$ + +Copyright (c) 2006-2007, Linden Research, Inc. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. +$/LicenseInfo$ +""" + +import datetime +import base64 +import struct +import time +import types +import re + +#from cElementTree import fromstring ## This does not work under Windows +try: + ## This is the old name of elementtree, for use with 2.3 + from elementtree.ElementTree import fromstring +except ImportError: + ## This is the name of elementtree under python 2.5 + from xml.etree.ElementTree import fromstring + +from indra.base import lluuid + +int_regex = re.compile("[-+]?\d+") +real_regex = re.compile("[-+]?(\d+(\.\d*)?|\d*\.\d+)([eE][-+]?\d+)?") +alpha_regex = re.compile("[a-zA-Z]+") +date_regex = re.compile("(?P\d{4})-(?P\d{2})-(?P\d{2})T(?P\d{2}):(?P\d{2}):(?P\d{2})(?P\.\d{2})?Z") +#date: d"YYYY-MM-DDTHH:MM:SS.FFZ" + +class LLSDParseError(Exception): + pass + +class LLSDSerializationError(Exception): + pass + + +class binary(str): + pass + +class uri(str): + pass + + +BOOL_TRUE = ('1', '1.0', 'true') +BOOL_FALSE = ('0', '0.0', 'false', '') + + +def bool_to_python(node): + val = node.text or '' + if val in BOOL_TRUE: + return True + else: + return False + +def int_to_python(node): + val = node.text or '' + if not val.strip(): + return 0 + return int(val) + +def real_to_python(node): + val = node.text or '' + if not val.strip(): + return 0.0 + return float(val) + +def uuid_to_python(node): + return lluuid.UUID(node.text) + +def str_to_python(node): + return unicode(node.text or '').encode('utf8', 'replace') + +def bin_to_python(node): + return binary(base64.decodestring(node.text or '')) + +def date_to_python(node): + val = node.text or '' + if not val: + val = "1970-01-01T00:00:00Z" + return datetime.datetime( + *time.strptime(val, '%Y-%m-%dT%H:%M:%SZ')[:6]) + +def uri_to_python(node): + val = node.text or '' + if not val: + return None + return uri(val) + +def map_to_python(node): + result = {} + for index in range(len(node))[::2]: + result[node[index].text] = to_python(node[index+1]) + return result + +def array_to_python(node): + return [to_python(child) for child in node] + + +NODE_HANDLERS = dict( + undef=lambda x: None, + boolean=bool_to_python, + integer=int_to_python, + real=real_to_python, + uuid=uuid_to_python, + string=str_to_python, + binary=bin_to_python, + date=date_to_python, + uri=uri_to_python, + map=map_to_python, + array=array_to_python, + ) + +def to_python(node): + return NODE_HANDLERS[node.tag](node) + +class Nothing(object): + pass + + +class LLSDXMLFormatter(object): + def __init__(self): + self.type_map = { + type(None) : self.UNDEF, + bool : self.BOOLEAN, + int : self.INTEGER, + long : self.INTEGER, + float : self.REAL, + lluuid.UUID : self.UUID, + binary : self.BINARY, + str : self.STRING, + unicode : self.STRING, + uri : self.URI, + datetime.datetime : self.DATE, + list : self.ARRAY, + tuple : self.ARRAY, + types.GeneratorType : self.ARRAY, + dict : self.MAP, + LLSD : self.LLSD + } + + def elt(self, name, contents=None): + if(contents is None or contents is ''): + return "<%s />" % (name,) + else: + return "<%s>%s" % (name, contents, name) + + def xml_esc(self, v): + return v.replace('&', '&').replace('<', '<').replace('>', '>') + + def LLSD(self, v): + return self.generate(v.thing) + def UNDEF(self, v): + return self.elt('undef') + def BOOLEAN(self, v): + if v: + return self.elt('boolean', 'true') + else: + return self.elt('boolean', 'false') + def INTEGER(self, v): + return self.elt('integer', v) + def REAL(self, v): + return self.elt('real', v) + def UUID(self, v): + if(v.isNull()): + return self.elt('uuid') + else: + return self.elt('uuid', v) + def BINARY(self, v): + return self.elt('binary', base64.encodestring(v)) + def STRING(self, v): + return self.elt('string', self.xml_esc(v)) + def URI(self, v): + return self.elt('uri', self.xml_esc(str(v))) + def DATE(self, v): + return self.elt('date', v.strftime('%Y-%m-%dT%H:%M:%SZ')) + def ARRAY(self, v): + return self.elt('array', ''.join([self.generate(item) for item in v])) + def MAP(self, v): + return self.elt( + 'map', + ''.join(["%s%s" % (self.elt('key', key), self.generate(value)) + for key, value in v.items()])) + + typeof = type + def generate(self, something): + t = self.typeof(something) + if self.type_map.has_key(t): + return self.type_map[t](something) + else: + raise LLSDSerializationError("Cannot serialize unknown type: %s (%s)" % ( + t, something)) + + def format(self, something): + return '' + self.elt("llsd", self.generate(something)) + +def format_xml(something): + return LLSDXMLFormatter().format(something) + +class LLSDNotationFormatter(object): + def __init__(self): + self.type_map = { + type(None) : self.UNDEF, + bool : self.BOOLEAN, + int : self.INTEGER, + long : self.INTEGER, + float : self.REAL, + lluuid.UUID : self.UUID, + binary : self.BINARY, + str : self.STRING, + unicode : self.STRING, + uri : self.URI, + datetime.datetime : self.DATE, + list : self.ARRAY, + tuple : self.ARRAY, + types.GeneratorType : self.ARRAY, + dict : self.MAP, + LLSD : self.LLSD + } + + def LLSD(self, v): + return self.generate(v.thing) + def UNDEF(self, v): + return '!' + def BOOLEAN(self, v): + if v: + return 'true' + else: + return 'false' + def INTEGER(self, v): + return "i%s" % v + def REAL(self, v): + return "r%s" % v + def UUID(self, v): + return "u%s" % v + def BINARY(self, v): + raise LLSDSerializationError("binary notation not yet supported") + def STRING(self, v): + return "'%s'" % v.replace("\\", "\\\\").replace("'", "\\'") + def URI(self, v): + return 'l"%s"' % str(v).replace("\\", "\\\\").replace('"', '\\"') + def DATE(self, v): + second_str = "" + if v.microsecond > 0: + seconds = v.second + float(v.microsecond) / 1000000 + second_str = "%05.2f" % seconds + else: + second_str = "%d" % v.second + return 'd"%s%sZ"' % (v.strftime('%Y-%m-%dT%H:%M:'), second_str) + def ARRAY(self, v): + return "[%s]" % ','.join([self.generate(item) for item in v]) + def MAP(self, v): + return "{%s}" % ','.join(["'%s':%s" % (key.replace("\\", "\\\\").replace("'", "\\'"), self.generate(value)) + for key, value in v.items()]) + + def generate(self, something): + t = type(something) + if self.type_map.has_key(t): + return self.type_map[t](something) + else: + raise LLSDSerializationError("Cannot serialize unknown type: %s (%s)" % ( + t, something)) + + def format(self, something): + return self.generate(something) + +def format_notation(something): + return LLSDNotationFormatter().format(something) + +def _hex_as_nybble(hex): + if (hex >= '0') and (hex <= '9'): + return ord(hex) - ord('0') + elif (hex >= 'a') and (hex <='f'): + return 10 + ord(hex) - ord('a') + elif (hex >= 'A') and (hex <='F'): + return 10 + ord(hex) - ord('A'); + +class LLSDBinaryParser(object): + def __init__(self): + pass + + def parse(self, buffer, ignore_binary = False): + """ + This is the basic public interface for parsing. + + @param buffer the binary data to parse in an indexable sequence. + @param ignore_binary parser throws away data in llsd binary nodes. + @return returns a python object. + """ + self._buffer = buffer + self._index = 0 + self._keep_binary = not ignore_binary + return self._parse() + + def _parse(self): + cc = self._buffer[self._index] + self._index += 1 + if cc == '{': + return self._parse_map() + elif cc == '[': + return self._parse_array() + elif cc == '!': + return None + elif cc == '0': + return False + elif cc == '1': + return True + elif cc == 'i': + # 'i' = integer + idx = self._index + self._index += 4 + return struct.unpack("!i", self._buffer[idx:idx+4])[0] + elif cc == ('r'): + # 'r' = real number + idx = self._index + self._index += 8 + return struct.unpack("!d", self._buffer[idx:idx+8])[0] + elif cc == 'u': + # 'u' = uuid + idx = self._index + self._index += 16 + return lluuid.uuid_bits_to_uuid(self._buffer[idx:idx+16]) + elif cc == 's': + # 's' = string + return self._parse_string() + elif cc in ("'", '"'): + # delimited/escaped string + return self._parse_string_delim(cc) + elif cc == 'l': + # 'l' = uri + return uri(self._parse_string()) + elif cc == ('d'): + # 'd' = date in seconds since epoch + idx = self._index + self._index += 8 + seconds = struct.unpack("!d", self._buffer[idx:idx+8])[0] + return datetime.datetime.fromtimestamp(seconds) + elif cc == 'b': + binary = self._parse_string() + if self._keep_binary: + return binary + # *NOTE: maybe have a binary placeholder which has the + # length. + return None + else: + raise LLSDParseError("invalid binary token at byte %d: %d" % ( + self._index - 1, ord(cc))) + + def _parse_map(self): + rv = {} + size = struct.unpack("!i", self._buffer[self._index:self._index+4])[0] + self._index += 4 + count = 0 + cc = self._buffer[self._index] + self._index += 1 + key = '' + while (cc != '}') and (count < size): + if cc == 'k': + key = self._parse_string() + elif cc in ("'", '"'): + key = self._parse_string_delim(cc) + else: + raise LLSDParseError("invalid map key at byte %d." % ( + self._index - 1,)) + value = self._parse() + #print "kv:",key,value + rv[key] = value + count += 1 + cc = self._buffer[self._index] + self._index += 1 + if cc != '}': + raise LLSDParseError("invalid map close token at byte %d." % ( + self._index,)) + return rv + + def _parse_array(self): + rv = [] + size = struct.unpack("!i", self._buffer[self._index:self._index+4])[0] + self._index += 4 + count = 0 + cc = self._buffer[self._index] + while (cc != ']') and (count < size): + rv.append(self._parse()) + count += 1 + cc = self._buffer[self._index] + if cc != ']': + raise LLSDParseError("invalid array close token at byte %d." % ( + self._index,)) + self._index += 1 + return rv + + def _parse_string(self): + size = struct.unpack("!i", self._buffer[self._index:self._index+4])[0] + self._index += 4 + rv = self._buffer[self._index:self._index+size] + self._index += size + return rv + + def _parse_string_delim(self, delim): + list = [] + found_escape = False + found_hex = False + found_digit = False + byte = 0 + while True: + cc = self._buffer[self._index] + self._index += 1 + if found_escape: + if found_hex: + if found_digit: + found_escape = False + found_hex = False + found_digit = False + byte <<= 4 + byte |= _hex_as_nybble(cc) + list.append(chr(byte)) + byte = 0 + else: + found_digit = True + byte = _hex_as_nybble(cc) + elif cc == 'x': + found_hex = True + else: + if cc == 'a': + list.append('\a') + elif cc == 'b': + list.append('\b') + elif cc == 'f': + list.append('\f') + elif cc == 'n': + list.append('\n') + elif cc == 'r': + list.append('\r') + elif cc == 't': + list.append('\t') + elif cc == 'v': + list.append('\v') + else: + list.append(cc) + found_escape = False + elif cc == '\\': + found_escape = True + elif cc == delim: + break + else: + list.append(cc) + return ''.join(list) + +class LLSDNotationParser(object): + """ Parse LLSD notation: + map: { string:object, string:object } + array: [ object, object, object ] + undef: ! + boolean: true | false | 1 | 0 | T | F | t | f | TRUE | FALSE + integer: i#### + real: r#### + uuid: u#### + string: "g'day" | 'have a "nice" day' | s(size)"raw data" + uri: l"escaped" + date: d"YYYY-MM-DDTHH:MM:SS.FFZ" + binary: b##"ff3120ab1" | b(size)"raw data" """ + def __init__(self): + pass + + def parse(self, buffer, ignore_binary = False): + """ + This is the basic public interface for parsing. + + @param buffer the notation string to parse. + @param ignore_binary parser throws away data in llsd binary nodes. + @return returns a python object. + """ + if buffer == "": + return False + + self._buffer = buffer + self._index = 0 + return self._parse() + + def _parse(self): + cc = self._buffer[self._index] + self._index += 1 + if cc == '{': + return self._parse_map() + elif cc == '[': + return self._parse_array() + elif cc == '!': + return None + elif cc == '0': + return False + elif cc == '1': + return True + elif cc in ('F', 'f'): + self._skip_alpha() + return False + elif cc in ('T', 't'): + self._skip_alpha() + return True + elif cc == 'i': + # 'i' = integer + return self._parse_integer() + elif cc == ('r'): + # 'r' = real number + return self._parse_real() + elif cc == 'u': + # 'u' = uuid + return self._parse_uuid() + elif cc in ("'", '"', 's'): + return self._parse_string(cc) + elif cc == 'l': + # 'l' = uri + delim = self._buffer[self._index] + self._index += 1 + val = uri(self._parse_string(delim)) + if len(val) == 0: + return None + return val + elif cc == ('d'): + # 'd' = date in seconds since epoch + return self._parse_date() + elif cc == 'b': + raise LLSDParseError("binary notation not yet supported") + else: + print cc + raise LLSDParseError("invalid token at index %d: %d" % ( + self._index - 1, ord(cc))) + + def _parse_map(self): + """ map: { string:object, string:object } """ + rv = {} + cc = self._buffer[self._index] + self._index += 1 + key = '' + found_key = False + while (cc != '}'): + if not found_key: + if cc in ("'", '"', 's'): + key = self._parse_string(cc) + found_key = True + #print "key:",key + elif cc.isspace() or cc == ',': + cc = self._buffer[self._index] + self._index += 1 + else: + raise LLSDParseError("invalid map key at byte %d." % ( + self._index - 1,)) + else: + if cc.isspace() or cc == ':': + #print "skipping whitespace '%s'" % cc + cc = self._buffer[self._index] + self._index += 1 + continue + self._index += 1 + value = self._parse() + #print "kv:",key,value + rv[key] = value + found_key = False + cc = self._buffer[self._index] + self._index += 1 + #if cc == '}': + # break + #cc = self._buffer[self._index] + #self._index += 1 + + return rv + + def _parse_array(self): + """ array: [ object, object, object ] """ + rv = [] + cc = self._buffer[self._index] + while (cc != ']'): + if cc.isspace() or cc == ',': + self._index += 1 + cc = self._buffer[self._index] + continue + rv.append(self._parse()) + cc = self._buffer[self._index] + + if cc != ']': + raise LLSDParseError("invalid array close token at index %d." % ( + self._index,)) + self._index += 1 + return rv + + def _parse_uuid(self): + match = re.match(lluuid.UUID.uuid_regex, self._buffer[self._index:]) + if not match: + raise LLSDParseError("invalid uuid token at index %d." % self._index) + + (start, end) = match.span() + start += self._index + end += self._index + self._index = end + return lluuid.UUID(self._buffer[start:end]) + + def _skip_alpha(self): + match = re.match(alpha_regex, self._buffer[self._index:]) + if match: + self._index += match.end() + + def _parse_date(self): + delim = self._buffer[self._index] + self._index += 1 + datestr = self._parse_string(delim) + + if datestr == "": + return datetime.datetime(1970, 1, 1) + + match = re.match(date_regex, datestr) + if not match: + raise LLSDParseError("invalid date string '%s'." % datestr) + + year = int(match.group('year')) + month = int(match.group('month')) + day = int(match.group('day')) + hour = int(match.group('hour')) + minute = int(match.group('minute')) + second = int(match.group('second')) + seconds_float = match.group('second_float') + microsecond = 0 + if seconds_float: + microsecond = int(seconds_float[1:]) * 10000 + return datetime.datetime(year, month, day, hour, minute, second, microsecond) + + def _parse_real(self): + match = re.match(real_regex, self._buffer[self._index:]) + if not match: + raise LLSDParseError("invalid real token at index %d." % self._index) + + (start, end) = match.span() + start += self._index + end += self._index + self._index = end + return float( self._buffer[start:end] ) + + def _parse_integer(self): + match = re.match(int_regex, self._buffer[self._index:]) + if not match: + raise LLSDParseError("invalid integer token at index %d." % self._index) + + (start, end) = match.span() + start += self._index + end += self._index + self._index = end + return int( self._buffer[start:end] ) + + def _parse_string(self, delim): + """ string: "g'day" | 'have a "nice" day' | s(size)"raw data" """ + rv = "" + + if delim in ("'", '"'): + rv = self._parse_string_delim(delim) + elif delim == 's': + rv = self._parse_string_raw() + else: + raise LLSDParseError("invalid string token at index %d." % self._index) + + return rv + + + def _parse_string_delim(self, delim): + """ string: "g'day 'un" | 'have a "nice" day' """ + list = [] + found_escape = False + found_hex = False + found_digit = False + byte = 0 + while True: + cc = self._buffer[self._index] + self._index += 1 + if found_escape: + if found_hex: + if found_digit: + found_escape = False + found_hex = False + found_digit = False + byte <<= 4 + byte |= _hex_as_nybble(cc) + list.append(chr(byte)) + byte = 0 + else: + found_digit = True + byte = _hex_as_nybble(cc) + elif cc == 'x': + found_hex = True + else: + if cc == 'a': + list.append('\a') + elif cc == 'b': + list.append('\b') + elif cc == 'f': + list.append('\f') + elif cc == 'n': + list.append('\n') + elif cc == 'r': + list.append('\r') + elif cc == 't': + list.append('\t') + elif cc == 'v': + list.append('\v') + else: + list.append(cc) + found_escape = False + elif cc == '\\': + found_escape = True + elif cc == delim: + break + else: + list.append(cc) + return ''.join(list) + + def _parse_string_raw(self): + """ string: s(size)"raw data" """ + # Read the (size) portion. + cc = self._buffer[self._index] + self._index += 1 + if cc != '(': + raise LLSDParseError("invalid string token at index %d." % self._index) + + rparen = self._buffer.find(')', self._index) + if rparen == -1: + raise LLSDParseError("invalid string token at index %d." % self._index) + + size = int(self._buffer[self._index:rparen]) + + self._index = rparen + 1 + delim = self._buffer[self._index] + self._index += 1 + if delim not in ("'", '"'): + raise LLSDParseError("invalid string token at index %d." % self._index) + + rv = self._buffer[self._index:(self._index + size)] + self._index += size + cc = self._buffer[self._index] + self._index += 1 + if cc != delim: + raise LLSDParseError("invalid string token at index %d." % self._index) + + return rv + +def format_binary(something): + return '\n' + _format_binary_recurse(something) + +def _format_binary_recurse(something): + if something is None: + return '!' + elif isinstance(something, LLSD): + return _format_binary_recurse(something.thing) + elif isinstance(something, bool): + if something: + return '1' + else: + return '0' + elif isinstance(something, (int, long)): + return 'i' + struct.pack('!i', something) + elif isinstance(something, float): + return 'r' + struct.pack('!d', something) + elif isinstance(something, lluuid.UUID): + return 'u' + something._bits + elif isinstance(something, binary): + return 'b' + struct.pack('!i', len(something)) + something + elif isinstance(something, (str, unicode)): + return 's' + struct.pack('!i', len(something)) + something + elif isinstance(something, uri): + return 'l' + struct.pack('!i', len(something)) + something + elif isinstance(something, datetime.datetime): + seconds_since_epoch = time.mktime(something.timetuple()) + return 'd' + struct.pack('!d', seconds_since_epoch) + elif isinstance(something, (list, tuple)): + array_builder = [] + array_builder.append('[' + struct.pack('!i', len(something))) + for item in something: + array_builder.append(_format_binary_recurse(item)) + array_builder.append(']') + return ''.join(array_builder) + elif isinstance(something, dict): + map_builder = [] + map_builder.append('{' + struct.pack('!i', len(something))) + for key, value in something.items(): + map_builder.append('k' + struct.pack('!i', len(key)) + key) + map_builder.append(_format_binary_recurse(value)) + map_builder.append('}') + return ''.join(map_builder) + else: + raise LLSDSerializationError("Cannot serialize unknown type: %s (%s)" % ( + type(something), something)) + + +def parse(something): + try: + if something.startswith(''): + just_binary = something.split('\n', 1)[1] + return LLSDBinaryParser().parse(just_binary) + # This should be better. + elif something.startswith('<'): + return to_python(fromstring(something)[0]) + else: + return LLSDNotationParser().parse(something) + except KeyError, e: + raise Exception('LLSD could not be parsed: %s' % (e,)) + +class LLSD(object): + def __init__(self, thing=None): + self.thing = thing + + def __str__(self): + return self.toXML(self.thing) + + parse = staticmethod(parse) + toXML = staticmethod(format_xml) + toBinary = staticmethod(format_binary) + toNotation = staticmethod(format_notation) + + +undef = LLSD(None) + +# register converters for stacked, if stacked is available +try: + from mulib import stacked + stacked.NoProducer() # just to exercise stacked +except: + print "Couldn't import mulib.stacked, not registering LLSD converters" +else: + def llsd_convert_json(llsd_stuff, request): + callback = request.get_header('callback') + if callback is not None: + ## See Yahoo's ajax documentation for information about using this + ## callback style of programming + ## http://developer.yahoo.com/common/json.html#callbackparam + req.write("%s(%s)" % (callback, simplejson.dumps(llsd_stuff))) + else: + req.write(simplejson.dumps(llsd_stuff)) + + def llsd_convert_xml(llsd_stuff, request): + request.write(format_xml(llsd_stuff)) + + def llsd_convert_binary(llsd_stuff, request): + request.write(format_binary(llsd_stuff)) + + for typ in [LLSD, dict, list, tuple, str, int, float, bool, unicode, type(None)]: + stacked.add_producer(typ, llsd_convert_json, 'application/json') + + stacked.add_producer(typ, llsd_convert_xml, 'application/llsd+xml') + stacked.add_producer(typ, llsd_convert_xml, 'application/xml') + stacked.add_producer(typ, llsd_convert_xml, 'text/xml') + + stacked.add_producer(typ, llsd_convert_binary, 'application/llsd+binary') + + stacked.add_producer(LLSD, llsd_convert_xml, '*/*') diff --git a/linden/indra/lib/python/indra/base/lluuid.py b/linden/indra/lib/python/indra/base/lluuid.py new file mode 100644 index 0000000..f302f8b --- /dev/null +++ b/linden/indra/lib/python/indra/base/lluuid.py @@ -0,0 +1,290 @@ +"""\ +@file lluuid.py +@brief UUID parser/generator. + +$LicenseInfo:firstyear=2004&license=mit$ + +Copyright (c) 2004-2007, Linden Research, Inc. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. +$/LicenseInfo$ +""" + +import md5, random, socket, string, time, re + +def _int2binstr(i,l): + s='' + for a in range(l): + s=chr(i&0xFF)+s + i>>=8 + return s + +def _binstr2int(s): + i = long(0) + for c in s: + i = (i<<8) + ord(c) + return i + +class UUID(object): + """ + A class which represents a 16 byte integer. Stored as a 16 byte 8 + bit character string. + + The string version is to be of the form: + AAAAAAAA-AAAA-BBBB-BBBB-BBBBBBCCCCCC (a 128-bit number in hex) + where A=network address, B=timestamp, C=random. + """ + + NULL_STR = "00000000-0000-0000-0000-000000000000" + + # the UUIDREGEX_STRING is helpful for parsing UUID's in text + hex_wildcard = r"[0-9a-fA-F]" + word = hex_wildcard + r"{4,4}-" + long_word = hex_wildcard + r"{8,8}-" + very_long_word = hex_wildcard + r"{12,12}" + UUID_REGEX_STRING = long_word + word + word + word + very_long_word + uuid_regex = re.compile(UUID_REGEX_STRING) + + rand = random.Random() + ip = '' + try: + ip = socket.gethostbyname(socket.gethostname()) + except(socket.gaierror): + # no ip address, so just default to somewhere in 10.x.x.x + ip = '10' + for i in range(3): + ip += '.' + str(rand.randrange(1,254)) + hexip = ''.join(["%04x" % long(i) for i in ip.split('.')]) + lastid = '' + + def __init__(self, string_with_uuid=None): + """ + Initialize to first valid UUID in string argument, + or to null UUID if none found or string is not supplied. + """ + self._bits = "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" + if string_with_uuid: + uuid_match = UUID.uuid_regex.search(string_with_uuid) + if uuid_match: + uuid_string = uuid_match.group() + s = string.replace(uuid_string, '-', '') + self._bits = _int2binstr(string.atol(s[:8],16),4) + \ + _int2binstr(string.atol(s[8:16],16),4) + \ + _int2binstr(string.atol(s[16:24],16),4) + \ + _int2binstr(string.atol(s[24:],16),4) + + def __len__(self): + """ + Used by the len() builtin. + """ + return 36 + + def __nonzero__(self): + return self._bits != "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" + + def __str__(self): + uuid_string = self.toString() + return uuid_string + + __repr__ = __str__ + + def __getitem__(self, index): + return str(self)[index] + + def __eq__(self, other): + if isinstance(other, (str, unicode)): + return other == str(self) + return self._bits == getattr(other, '_bits', '') + + def __ne__(self, other): + return not self.__eq__(other) + + def __le__(self, other): + return self._bits <= other._bits + + def __ge__(self, other): + return self._bits >= other._bits + + def __lt__(self, other): + return self._bits < other._bits + + def __gt__(self, other): + return self._bits > other._bits + + def __hash__(self): + return hash(self._bits) + + def set(self, uuid): + self._bits = uuid._bits + + def setFromString(self, uuid_string): + """ + Given a string version of a uuid, set self bits + appropriately. Returns self. + """ + s = string.replace(uuid_string, '-', '') + self._bits = _int2binstr(string.atol(s[:8],16),4) + \ + _int2binstr(string.atol(s[8:16],16),4) + \ + _int2binstr(string.atol(s[16:24],16),4) + \ + _int2binstr(string.atol(s[24:],16),4) + return self + + def setFromMemoryDump(self, gdb_string): + """ + We expect to get gdb_string as four hex units. eg: + 0x147d54db 0xc34b3f1b 0x714f989b 0x0a892fd2 + Which will be translated to: + db547d14-1b3f4bc3-9b984f71-d22f890a + Returns self. + """ + s = string.replace(gdb_string, '0x', '') + s = string.replace(s, ' ', '') + t = '' + for i in range(8,40,8): + for j in range(0,8,2): + t = t + s[i-j-2:i-j] + self.setFromString(t) + + def toString(self): + """ + Return as a string matching the LL standard + AAAAAAAA-AAAA-BBBB-BBBB-BBBBBBCCCCCC (a 128-bit number in hex) + where A=network address, B=timestamp, C=random. + """ + return uuid_bits_to_string(self._bits) + + def getAsString(self): + """ + Return a different string representation of the form + AAAAAAAA-AAAABBBB-BBBBBBBB-BBCCCCCC (a 128-bit number in hex) + where A=network address, B=timestamp, C=random. + """ + i1 = _binstr2int(self._bits[0:4]) + i2 = _binstr2int(self._bits[4:8]) + i3 = _binstr2int(self._bits[8:12]) + i4 = _binstr2int(self._bits[12:16]) + return '%08lx-%08lx-%08lx-%08lx' % (i1,i2,i3,i4) + + def generate(self): + """ + Generate a new uuid. This algorithm is slightly different + from c++ implementation for portability reasons. + Returns self. + """ + newid = self.__class__.lastid + while newid == self.__class__.lastid: + now = long(time.time() * 1000) + newid = ("%016x" % now) + self.__class__.hexip + newid += ("%03x" % (self.__class__.rand.randrange(0,4095))) + self.__class__.lastid = newid + m = md5.new() + m.update(newid) + self._bits = m.digest() + return self + + def isNull(self): + """ + Returns 1 if the uuid is null - ie, equal to default uuid. + """ + return (self._bits == "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0") + + def xor(self, rhs): + """ + xors self with rhs. + """ + v1 = _binstr2int(self._bits[0:4]) ^ _binstr2int(rhs._bits[0:4]) + v2 = _binstr2int(self._bits[4:8]) ^ _binstr2int(rhs._bits[4:8]) + v3 = _binstr2int(self._bits[8:12]) ^ _binstr2int(rhs._bits[8:12]) + v4 = _binstr2int(self._bits[12:16]) ^ _binstr2int(rhs._bits[12:16]) + self._bits = _int2binstr(v1,4) + \ + _int2binstr(v2,4) + \ + _int2binstr(v3,4) + \ + _int2binstr(v4,4) + +def printTranslatedMemory(four_hex_uints): + """ + We expect to get the string as four hex units. eg: + 0x147d54db 0xc34b3f1b 0x714f989b 0x0a892fd2 + Which will be translated to: + db547d14-1b3f4bc3-9b984f71-d22f890a + """ + uuid = UUID() + uuid.setFromMemoryDump(four_hex_uints) + print uuid.toString() + +def isPossiblyID(id_str): + """ + This function returns 1 if the string passed has some uuid-like + characteristics. Otherwise returns 0. + """ + if not id_str or len(id_str) < 5 or len(id_str) > 36: + return 0 + + if isinstance(id_str, UUID) or UUID.uuid_regex.match(id_str): + return 1 + # build a string which matches every character. + hex_wildcard = r"[0-9a-fA-F]" + chars = len(id_str) + next = min(chars, 8) + matcher = hex_wildcard+"{"+str(next)+","+str(next)+"}" + chars = chars - next + if chars > 0: + matcher = matcher + "-" + chars = chars - 1 + for block in range(3): + next = max(min(chars, 4), 0) + if next: + matcher = matcher + hex_wildcard+"{"+str(next)+","+str(next)+"}" + chars = chars - next + if chars > 0: + matcher = matcher + "-" + chars = chars - 1 + if chars > 0: + next = min(chars, 12) + matcher = matcher + hex_wildcard+"{"+str(next)+","+str(next)+"}" + #print matcher + uuid_matcher = re.compile(matcher) + if uuid_matcher.match(id_str): + return 1 + return 0 + +def uuid_bits_to_string(bits): + i1 = _binstr2int(bits[0:4]) + i2 = _binstr2int(bits[4:6]) + i3 = _binstr2int(bits[6:8]) + i4 = _binstr2int(bits[8:10]) + i5 = _binstr2int(bits[10:12]) + i6 = _binstr2int(bits[12:16]) + return '%08lx-%04lx-%04lx-%04lx-%04lx%08lx' % (i1,i2,i3,i4,i5,i6) + +def uuid_bits_to_uuid(bits): + return UUID(uuid_bits_to_string(bits)) + + +try: + from mulib import stacked + stacked.NoProducer() # just to exercise stacked +except: + print "Couldn't import mulib.stacked, not registering UUID converter" +else: + def convertUUID(uuid, req): + req.write(str(uuid)) + + stacked.add_producer(UUID, convertUUID, "*/*") + stacked.add_producer(UUID, convertUUID, "text/html") diff --git a/linden/indra/lib/python/indra/ipc/__init__.py b/linden/indra/lib/python/indra/ipc/__init__.py index 92c9416..4395361 100644 --- a/linden/indra/lib/python/indra/ipc/__init__.py +++ b/linden/indra/lib/python/indra/ipc/__init__.py @@ -2,26 +2,26 @@ @file __init__.py @brief Initialization file for the indra ipc module. +$LicenseInfo:firstyear=2006&license=mit$ + Copyright (c) 2006-2007, Linden Research, Inc. -# Second Life Viewer Source Code -# The source code in this file ("Source Code") is provided by Linden Lab -# to you under the terms of the GNU General Public License, version 2.0 -# ("GPL"), unless you have obtained a separate licensing agreement -# ("Other License"), formally executed by you and Linden Lab. Terms of -# the GPL can be found in doc/GPL-license.txt in this distribution, or -# online at http://secondlife.com/developers/opensource/gplv2 -# -# There are special exceptions to the terms and conditions of the GPL as -# it is applied to this Source Code. View the full text of the exception -# in the file doc/FLOSS-exception.txt in this software distribution, or -# online at http://secondlife.com/developers/opensource/flossexception -# -# By copying, modifying or distributing this software, you acknowledge -# that you have read and understood your obligations described above, -# and agree to abide by those obligations. -# -# ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO -# WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, -# COMPLETENESS OR PERFORMANCE. +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. +$/LicenseInfo$ """ diff --git a/linden/indra/lib/python/indra/ipc/compatibility.py b/linden/indra/lib/python/indra/ipc/compatibility.py index 358820c..8435528 100644 --- a/linden/indra/lib/python/indra/ipc/compatibility.py +++ b/linden/indra/lib/python/indra/ipc/compatibility.py @@ -2,28 +2,28 @@ @file compatibility.py @brief Classes that manage compatibility states. +$LicenseInfo:firstyear=2007&license=mit$ + Copyright (c) 2007, Linden Research, Inc. -# Second Life Viewer Source Code -# The source code in this file ("Source Code") is provided by Linden Lab -# to you under the terms of the GNU General Public License, version 2.0 -# ("GPL"), unless you have obtained a separate licensing agreement -# ("Other License"), formally executed by you and Linden Lab. Terms of -# the GPL can be found in doc/GPL-license.txt in this distribution, or -# online at http://secondlife.com/developers/opensource/gplv2 -# -# There are special exceptions to the terms and conditions of the GPL as -# it is applied to this Source Code. View the full text of the exception -# in the file doc/FLOSS-exception.txt in this software distribution, or -# online at http://secondlife.com/developers/opensource/flossexception -# -# By copying, modifying or distributing this software, you acknowledge -# that you have read and understood your obligations described above, -# and agree to abide by those obligations. -# -# ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO -# WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, -# COMPLETENESS OR PERFORMANCE. +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. +$/LicenseInfo$ """ diff --git a/linden/indra/lib/python/indra/ipc/httputil.py b/linden/indra/lib/python/indra/ipc/httputil.py new file mode 100644 index 0000000..c4ac0a3 --- /dev/null +++ b/linden/indra/lib/python/indra/ipc/httputil.py @@ -0,0 +1,9 @@ + +import warnings + +warnings.warn("indra.ipc.httputil has been deprecated; use eventlet.httpc instead", DeprecationWarning, 2) + +from eventlet.httpc import * + + +makeConnection = make_connection diff --git a/linden/indra/lib/python/indra/ipc/llmessage.py b/linden/indra/lib/python/indra/ipc/llmessage.py index de6fd3b..2497393 100644 --- a/linden/indra/lib/python/indra/ipc/llmessage.py +++ b/linden/indra/lib/python/indra/ipc/llmessage.py @@ -2,28 +2,28 @@ @file llmessage.py @brief Message template parsing and compatiblity +$LicenseInfo:firstyear=2007&license=mit$ + Copyright (c) 2007, Linden Research, Inc. -# Second Life Viewer Source Code -# The source code in this file ("Source Code") is provided by Linden Lab -# to you under the terms of the GNU General Public License, version 2.0 -# ("GPL"), unless you have obtained a separate licensing agreement -# ("Other License"), formally executed by you and Linden Lab. Terms of -# the GPL can be found in doc/GPL-license.txt in this distribution, or -# online at http://secondlife.com/developers/opensource/gplv2 -# -# There are special exceptions to the terms and conditions of the GPL as -# it is applied to this Source Code. View the full text of the exception -# in the file doc/FLOSS-exception.txt in this software distribution, or -# online at http://secondlife.com/developers/opensource/flossexception -# -# By copying, modifying or distributing this software, you acknowledge -# that you have read and understood your obligations described above, -# and agree to abide by those obligations. -# -# ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO -# WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, -# COMPLETENESS OR PERFORMANCE. +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. +$/LicenseInfo$ """ from sets import Set, ImmutableSet diff --git a/linden/indra/lib/python/indra/ipc/llsdhttp.py b/linden/indra/lib/python/indra/ipc/llsdhttp.py new file mode 100644 index 0000000..0d1a1c6 --- /dev/null +++ b/linden/indra/lib/python/indra/ipc/llsdhttp.py @@ -0,0 +1,84 @@ +"""\ +@file llsdhttp.py +@brief Functions to ease moving llsd over http + +$LicenseInfo:firstyear=2006&license=mit$ + +Copyright (c) 2006-2007, Linden Research, Inc. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. +$/LicenseInfo$ +""" + +import os.path +import os +import urlparse + +from indra.base import llsd + +from eventlet import httpc + + +get, put, delete, post = httpc.make_suite( + llsd.format_xml, llsd.parse, 'application/xml+llsd') + + +for x in (httpc.ConnectionError, httpc.NotFound, httpc.Forbidden): + globals()[x.__name__] = x + + +def postFile(url, filename, verbose=False): + f = open(filename) + body = f.read() + f.close() + llsd_body = llsd.parse(body) + return post(url, llsd_body, verbose=verbose) + + +def getStatus(url, use_proxy=False): + status, _headers, _body = get(url, use_proxy=use_proxy, verbose=True) + return status + + +def putStatus(url, data): + status, _headers, _body = put(url, data, verbose=True) + return status + + +def deleteStatus(url): + status, _headers, _body = delete(url, verbose=True) + return status + + +def postStatus(url, data): + status, _headers, _body = post(url, data, verbose=True) + return status + + +def postFileStatus(url, filename): + status, _headers, body = postFile(url, filename, verbose=True) + return status, body + + +def getFromSimulator(path, use_proxy=False): + return get('http://' + simulatorHostAndPort + path, use_proxy=use_proxy) + + +def postToSimulator(path, data=None): + return post('http://' + simulatorHostAndPort + path, data) diff --git a/linden/indra/lib/python/indra/ipc/mysql_pool.py b/linden/indra/lib/python/indra/ipc/mysql_pool.py new file mode 100644 index 0000000..4a265a1 --- /dev/null +++ b/linden/indra/lib/python/indra/ipc/mysql_pool.py @@ -0,0 +1,103 @@ +"""\ +@file mysql_pool.py +@brief Uses saranwrap to implement a pool of nonblocking database connections to a mysql server. + +$LicenseInfo:firstyear=2007&license=mit$ + +Copyright (c) 2007, Linden Research, Inc. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. +$/LicenseInfo$ +""" + +import os + +from eventlet.pools import Pool +from eventlet.processes import DeadProcess +from indra.ipc import saranwrap + +import MySQLdb + +# method 2: better -- admits the existence of the pool +# dbp = my_db_connector.get() +# dbh = dbp.get() +# dbc = dbh.cursor() +# dbc.execute(named_query) +# dbc.close() +# dbp.put(dbh) + +class DatabaseConnector(object): + """\ +@brief This is an object which will maintain a collection of database +connection pools keyed on host,databasename""" + def __init__(self, credentials, min_size = 0, max_size = 4, *args, **kwargs): + """\ + @brief constructor + @param min_size the minimum size of a child pool. + @param max_size the maximum size of a child pool.""" + self._min_size = min_size + self._max_size = max_size + self._args = args + self._kwargs = kwargs + self._credentials = credentials # this is a map of hostname to username/password + self._databases = {} + + def credentials_for(self, host): + if host in self._credentials: + return self._credentials[host] + else: + return self._credentials.get('default', None) + + def get(self, host, dbname): + key = (host, dbname) + if key not in self._databases: + new_kwargs = self._kwargs.copy() + new_kwargs['db'] = dbname + new_kwargs['host'] = host + new_kwargs.update(self.credentials_for(host)) + dbpool = ConnectionPool(self._min_size, self._max_size, *self._args, **new_kwargs) + self._databases[key] = dbpool + + return self._databases[key] + + +class ConnectionPool(Pool): + """A pool which gives out saranwrapped MySQLdb connections from a pool + """ + def __init__(self, min_size = 0, max_size = 4, *args, **kwargs): + self._args = args + self._kwargs = kwargs + Pool.__init__(self, min_size, max_size) + + def create(self): + return saranwrap.wrap(MySQLdb).connect(*self._args, **self._kwargs) + + def put(self, conn): + # rollback any uncommitted changes, so that the next process + # has a clean slate. This also pokes the process to see if + # it's dead or None + try: + conn.rollback() + except (AttributeError, DeadProcess), e: + conn = self.create() + # TODO figure out if we're still connected to the database + if conn: + Pool.put(self, conn) + else: + self.current_size -= 1 diff --git a/linden/indra/lib/python/indra/ipc/russ.py b/linden/indra/lib/python/indra/ipc/russ.py new file mode 100644 index 0000000..1ef5562 --- /dev/null +++ b/linden/indra/lib/python/indra/ipc/russ.py @@ -0,0 +1,157 @@ +"""\ +@file russ.py +@brief Recursive URL Substitution Syntax helpers +@author Phoenix + +Many details on how this should work is available on the wiki: +https://wiki.secondlife.com/wiki/Recursive_URL_Substitution_Syntax + +Adding features to this should be reflected in that page in the +implementations section. + +$LicenseInfo:firstyear=2007&license=mit$ + +Copyright (c) 2007, Linden Research, Inc. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. +$/LicenseInfo$ +""" + +import urllib +from indra.ipc import llsdhttp + +class UnbalancedBraces(Exception): + pass + +class UnknownDirective(Exception): + pass + +class BadDirective(Exception): + pass + +def format_value_for_path(value): + if type(value) in [list, tuple]: + # *NOTE: treat lists as unquoted path components so that the quoting + # doesn't get out-of-hand. This is a workaround for the fact that + # russ always quotes, even if the data it's given is already quoted, + # and it's not safe to simply unquote a path directly, so if we want + # russ to substitute urls parts inside other url parts we always + # have to do so via lists of unquoted path components. + return '/'.join([urllib.quote(str(item)) for item in value]) + else: + return urllib.quote(str(value)) + +def format(format_str, context): + """@brief Format format string according to rules for RUSS. +@see https://osiris.lindenlab.com/mediawiki/index.php/Recursive_URL_Substitution_Syntax +@param format_str The input string to format. +@param context A map used for string substitutions. +@return Returns the formatted string. If no match, the braces remain intact. +""" + while True: + #print "format_str:", format_str + all_matches = _find_sub_matches(format_str) + if not all_matches: + break + substitutions = 0 + while True: + matches = all_matches.pop() + # we work from right to left to make sure we do not + # invalidate positions earlier in format_str + matches.reverse() + for pos in matches: + # Use index since _find_sub_matches should have raised + # an exception, and failure to find now is an exception. + end = format_str.index('}', pos) + #print "directive:", format_str[pos+1:pos+5] + if format_str[pos + 1] == '$': + value = context[format_str[pos + 2:end]] + if value is not None: + value = format_value_for_path(value) + elif format_str[pos + 1] == '%': + value = _build_query_string( + context.get(format_str[pos + 2:end])) + elif format_str[pos+1:pos+5] == 'http' or format_str[pos+1:pos+5] == 'file': + value = _fetch_url_directive(format_str[pos + 1:end]) + else: + raise UnknownDirective, format_str[pos:end + 1] + if value is not None: + format_str = format_str[:pos]+str(value)+format_str[end+1:] + substitutions += 1 + + # If there were any substitutions at this depth, re-parse + # since this may have revealed new things to substitute + if substitutions: + break + if not all_matches: + break + + # If there were no substitutions at all, and we have exhausted + # the possible matches, bail. + if not substitutions: + break + return format_str + +def _find_sub_matches(format_str): + """@brief Find all of the substitution matches. +@param format_str the RUSS conformant format string. +@return Returns an array of depths of arrays of positional matches in input. +""" + depth = 0 + matches = [] + for pos in range(len(format_str)): + if format_str[pos] == '{': + depth += 1 + if not len(matches) == depth: + matches.append([]) + matches[depth - 1].append(pos) + continue + if format_str[pos] == '}': + depth -= 1 + continue + if not depth == 0: + raise UnbalancedBraces, format_str + return matches + +def _build_query_string(query_dict): + """\ + @breif given a dict, return a query string. utility wrapper for urllib. + @param query_dict input query dict + @returns Returns an urlencoded query string including leading '?'. + """ + if query_dict: + return '?' + urllib.urlencode(query_dict) + else: + return '' + +def _fetch_url_directive(directive): + "*FIX: This only supports GET" + commands = directive.split('|') + resource = llsdhttp.get(commands[0]) + if len(commands) == 3: + resource = _walk_resource(resource, commands[2]) + return resource + +def _walk_resource(resource, path): + path = path.split('/') + for child in path: + if not child: + continue + resource = resource[child] + return resource diff --git a/linden/indra/lib/python/indra/ipc/saranwrap.py b/linden/indra/lib/python/indra/ipc/saranwrap.py new file mode 100644 index 0000000..31705c4 --- /dev/null +++ b/linden/indra/lib/python/indra/ipc/saranwrap.py @@ -0,0 +1,637 @@ +"""\ +@file saranwrap.py +@author Phoenix +@date 2007-07-13 +@brief A simple, pickle based rpc mechanism which reflects python +objects and callables. + +$LicenseInfo:firstyear=2007&license=mit$ + +Copyright (c) 2007, Linden Research, Inc. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. +$/LicenseInfo$ + +This file provides classes and exceptions used for simple python level +remote procedure calls. This is achieved by intercepting the basic +getattr and setattr calls in a client proxy, which commnicates those +down to the server which will dispatch them to objects in it's process +space. + +The basic protocol to get and set attributes is for the client proxy +to issue the command: + +getattr $id $name +setattr $id $name $value + +getitem $id $item +setitem $id $item $value +eq $id $rhs +del $id + +When the get returns a callable, the client proxy will provide a +callable proxy which will invoke a remote procedure call. The command +issued from the callable proxy to server is: + +call $id $name $args $kwargs + +If the client supplies an id of None, then the get/set/call is applied +to the object(s) exported from the server. + +The server will parse the get/set/call, take the action indicated, and +return back to the caller one of: + +value $val +callable +object $id +exception $excp + +To handle object expiration, the proxy will instruct the rpc server to +discard objects which are no longer in use. This is handled by +catching proxy deletion and sending the command: + +del $id + +The server will handle this by removing clearing it's own internal +references. This does not mean that the object will necessarily be +cleaned from the server, but no artificial references will remain +after successfully completing. On completion, the server will return +one of: + +value None +exception $excp + +The server also accepts a special command for debugging purposes: + +status + +Which will be intercepted by the server to write back: + +status {...} + +The wire protocol is to pickle the Request class in this file. The +request class is basically an action and a map of parameters' +""" + +import os +import cPickle +import struct +import sys + +try: + set = set + frozenset = frozenset +except NameError: + from sets import Set as set, ImmutableSet as frozenset + +from eventlet.processes import Process +from eventlet import api + +# +# debugging hooks +# +_g_debug_mode = False +if _g_debug_mode: + import traceback + + +def wrap(obj, dead_callback = None): + """ +@brief wrap in object in another process through a saranwrap proxy +@param object The object to wrap. +@param dead_callback A callable to invoke if the process exits.""" + + if type(obj).__name__ == 'module': + return wrap_module(obj.__name__, dead_callback) + p = Process('python', [__file__, '--child'], dead_callback) + prox = Proxy(p, p) + prox.obj = obj + return prox.obj + +def wrap_module(fqname, dead_callback = None): + """ +@brief wrap a module in another process through a saranwrap proxy +@param fqname The fully qualified name of the module. +@param dead_callback A callable to invoke if the process exits.""" + global _g_debug_mode + if _g_debug_mode: + p = Process('python', [__file__, '--module', fqname, '--logfile', '/tmp/saranwrap.log'], dead_callback) + else: + p = Process('python', [__file__, '--module', fqname,], dead_callback) + prox = Proxy(p, p) + return prox + +def status(proxy): + """ +@brief get the status from the server through a proxy +@param proxy a saranwrap.Proxy object connected to a server.""" + _write_request(Request('status', {}), proxy.__local_dict['_out']) + return _read_response(None, None, proxy.__local_dict['_in'], proxy.__local_dict['_out'], None) + +class BadResponse(Exception): + """"This exception is raised by an saranwrap client when it could + parse but cannot understand the response from the server.""" + pass + +class BadRequest(Exception): + """"This exception is raised by a saranwrap server when it could parse + but cannot understand the response from the server.""" + pass + +class UnrecoverableError(Exception): + pass + +class Request(object): + "@brief A wrapper class for proxy requests to the server." + def __init__(self, action, param): + self._action = action + self._param = param + def __str__(self): + return "Request `"+self._action+"` "+str(self._param) + def __getitem__(self, name): + return self._param[name] + def action(self): + return self._action + +def _read_lp_hunk(stream): + len_bytes = stream.read(4) + length = struct.unpack('I', len_bytes)[0] + body = stream.read(length) + return body + +def _read_response(id, attribute, input, output, dead_list): + """@brief local helper method to read respones from the rpc server.""" + try: + str = _read_lp_hunk(input) + _prnt(`str`) + response = cPickle.loads(str) + except AttributeError, e: + raise UnrecoverableError(e) + _prnt("response: %s" % response) + if response[0] == 'value': + return response[1] + elif response[0] == 'callable': + return CallableProxy(id, attribute, input, output, dead_list) + elif response[0] == 'object': + return ObjectProxy(input, output, response[1], dead_list) + elif response[0] == 'exception': + exp = response[1] + raise exp + else: + raise BadResponse(response[0]) + +def _write_lp_hunk(stream, hunk): + write_length = struct.pack('I', len(hunk)) + stream.write(write_length + hunk) + if hasattr(stream, 'flush'): + stream.flush() + +def _write_request(param, output): + _prnt("request: %s" % param) + str = cPickle.dumps(param) + _write_lp_hunk(output, str) + +def _is_local(attribute): + "Return true if the attribute should be handled locally" +# return attribute in ('_in', '_out', '_id', '__getattribute__', '__setattr__', '__dict__') + # good enough for now. :) + if '__local_dict' in attribute: + return True + return False + +def _prnt(message): + global _g_debug_mode + if _g_debug_mode: + print message + +_g_logfile = None +def _log(message): + global _g_logfile + if _g_logfile: + _g_logfile.write(str(os.getpid()) + ' ' + message) + _g_logfile.write('\n') + _g_logfile.flush() + +def _unmunge_attr_name(name): + """ Sometimes attribute names come in with classname prepended, not sure why. + This function removes said classname, because we're huge hackers and we didn't + find out what the true right thing to do is. *FIX: find out. """ + if(name.startswith('_Proxy')): + name = name[len('_Proxy'):] + if(name.startswith('_ObjectProxy')): + name = name[len('_ObjectProxy'):] + return name + + +class Proxy(object): + """\ +@class Proxy +@brief This class wraps a remote python process, presumably available +in an instance of an Server. + +This is the class you will typically use as a client to a child +process. Simply instantiate one around a file-like interface and start +calling methods on the thing that is exported. The dir() builtin is +not supported, so you have to know what has been exported. +""" + def __init__(self, input, output, dead_list = None): + """\ +@param input a file-like object which supports read(). +@param output a file-like object which supports write() and flush(). +@param id an identifier for the remote object. humans do not provide this. +""" + # default dead_list inside the function because all objects in method + # argument lists are init-ed only once globally + if dead_list is None: + dead_list = set() + #_prnt("Proxy::__init__") + self.__local_dict = dict( + _in = input, + _out = output, + _dead_list = dead_list, + _id = None) + + def __getattribute__(self, attribute): + #_prnt("Proxy::__getattr__: %s" % attribute) + if _is_local(attribute): + # call base class getattribute so we actually get the local variable + attribute = _unmunge_attr_name(attribute) + return super(Proxy, self).__getattribute__(attribute) + else: + my_in = self.__local_dict['_in'] + my_out = self.__local_dict['_out'] + my_id = self.__local_dict['_id'] + _dead_list = self.__local_dict['_dead_list'] + for dead_object in _dead_list: + request = Request('del', {'id':dead_object}) + _write_request(request, my_out) + response = _read_response(my_id, attribute, my_in, my_out, _dead_list) + _dead_list.clear() + + # Pass all public attributes across to find out if it is + # callable or a simple attribute. + request = Request('getattr', {'id':my_id, 'attribute':attribute}) + _write_request(request, my_out) + return _read_response(my_id, attribute, my_in, my_out, _dead_list) + + def __setattr__(self, attribute, value): + #_prnt("Proxy::__setattr__: %s" % attribute) + if _is_local(attribute): + # It must be local to this actual object, so we have to apply + # it to the dict in a roundabout way + attribute = _unmunge_attr_name(attribute) + super(Proxy, self).__getattribute__('__dict__')[attribute]=value + else: + my_in = self.__local_dict['_in'] + my_out = self.__local_dict['_out'] + my_id = self.__local_dict['_id'] + _dead_list = self.__local_dict['_dead_list'] + # Pass the set attribute across + request = Request('setattr', {'id':my_id, 'attribute':attribute, 'value':value}) + _write_request(request, my_out) + return _read_response(my_id, attribute, my_in, my_out, _dead_list) + +class ObjectProxy(Proxy): + """\ +@class ObjectProxy +@brief This class wraps a remote object in the Server + +This class will be created during normal operation, and users should +not need to deal with this class directly.""" + + def __init__(self, input, output, id, dead_list): + """\ +@param input a file-like object which supports read(). +@param output a file-like object which supports write() and flush(). +@param id an identifier for the remote object. humans do not provide this. +""" + Proxy.__init__(self, input, output, dead_list) + self.__local_dict['_id'] = id + #_prnt("ObjectProxy::__init__ %s" % self._id) + + def __del__(self): + my_id = self.__local_dict['_id'] + #_prnt"ObjectProxy::__del__ %s" % my_id + self.__local_dict['_dead_list'].add(my_id) + + def __getitem__(self, key): + my_in = self.__local_dict['_in'] + my_out = self.__local_dict['_out'] + my_id = self.__local_dict['_id'] + _dead_list = self.__local_dict['_dead_list'] + request = Request('getitem', {'id':my_id, 'key':key}) + _write_request(request, my_out) + return _read_response(my_id, key, my_in, my_out, _dead_list) + + def __setitem__(self, key, value): + my_in = self.__local_dict['_in'] + my_out = self.__local_dict['_out'] + my_id = self.__local_dict['_id'] + _dead_list = self.__local_dict['_dead_list'] + request = Request('setitem', {'id':my_id, 'key':key, 'value':value}) + _write_request(request, my_out) + return _read_response(my_id, key, my_in, my_out, _dead_list) + + def __eq__(self, rhs): + my_in = self.__local_dict['_in'] + my_out = self.__local_dict['_out'] + my_id = self.__local_dict['_id'] + _dead_list = self.__local_dict['_dead_list'] + request = Request('eq', {'id':my_id, 'rhs':rhs.__local_dict['_id']}) + _write_request(request, my_out) + return _read_response(my_id, None, my_in, my_out, _dead_list) + + def __repr__(self): + # apparently repr(obj) skips the whole getattribute thing and just calls __repr__ + # directly. Therefore we just pass it through the normal call pipeline, and + # tack on a little header so that you can tell it's an object proxy. + val = self.__repr__() + return "saran:%s" % val + + def __str__(self): + # see description for __repr__, because str(obj) works the same. We don't + # tack anything on to the return value here because str values are used as data. + return self.__str__() + +def proxied_type(self): + if type(self) is not ObjectProxy: + return type(self) + + my_in = self.__local_dict['_in'] + my_out = self.__local_dict['_out'] + my_id = self.__local_dict['_id'] + request = Request('type', {'id':my_id}) + _write_request(request, my_out) + # dead list can be none because we know the result will always be + # a value and not an ObjectProxy itself + return _read_response(my_id, None, my_in, my_out, None) + +class CallableProxy(object): + """\ +@class CallableProxy +@brief This class wraps a remote function in the Server + +This class will be created by an Proxy during normal operation, +and users should not need to deal with this class directly.""" + + def __init__(self, object_id, name, input, output, dead_list): + #_prnt("CallableProxy::__init__: %s, %s" % (object_id, name)) + self._object_id = object_id + self._name = name + self._in = input + self._out = output + self._dead_list = dead_list + + def __call__(self, *args, **kwargs): + #_prnt("CallableProxy::__call__: %s, %s" % (args, kwargs)) + + # Pass the call across. We never build a callable without + # having already checked if the method starts with '_' so we + # can safely pass this one to the remote object. + #_prnt("calling %s %s" % (self._object_id, self._name) + request = Request('call', {'id':self._object_id, 'name':self._name, 'args':args, 'kwargs':kwargs}) + _write_request(request, self._out) + return _read_response(self._object_id, self._name, self._in, self._out, self._dead_list) + +class Server(object): + def __init__(self, input, output, export): + """\ +@param input a file-like object which supports read(). +@param output a file-like object which supports write() and flush(). +@param export an object, function, or map which is exported to clients +when the id is None.""" + #_log("Server::__init__") + self._in = input + self._out = output + self._export = export + self._next_id = 1 + self._objects = {} + + def handle_status(self, object, req): + return { + 'object_count':len(self._objects), + 'next_id':self._next_id, + 'pid':os.getpid()} + + def handle_getattr(self, object, req): + try: + return getattr(object, req['attribute']) + except AttributeError, e: + if hasattr(object, "__getitem__"): + return object[req['attribute']] + else: + raise e + #_log('getattr: %s' % str(response)) + + def handle_setattr(self, object, req): + try: + return setattr(object, req['attribute'], req['value']) + except AttributeError, e: + if hasattr(object, "__setitem__"): + return object.__setitem__(req['attribute'], req['value']) + else: + raise e + + def handle_getitem(self, object, req): + return object[req['key']] + + def handle_setitem(self, object, req): + object[req['key']] = req['value'] + return None # *TODO figure out what the actual return value of __setitem__ should be + + def handle_eq(self, object, req): + #_log("__eq__ %s %s" % (object, req)) + rhs = None + try: + rhs = self._objects[req['rhs']] + except KeyError, e: + return False + return (object == rhs) + + def handle_call(self, object, req): + #_log("calling %s " % (req['name'])) + try: + fn = getattr(object, req['name']) + except AttributeError, e: + if hasattr(object, "__setitem__"): + fn = object[req['name']] + else: + raise e + + return fn(*req['args'],**req['kwargs']) + + def handle_del(self, object, req): + id = req['id'] + _log("del %s from %s" % (id, self._objects)) + + # *TODO what does __del__ actually return? + del self._objects[id] + return None + + def handle_type(self, object, req): + return type(object) + + def loop(self): + """@brief Loop forever and respond to all requests.""" + _log("Server::loop") + while True: + try: + try: + str = _read_lp_hunk(self._in) + except EOFError: + sys.exit(0) # normal exit + request = cPickle.loads(str) + _log("request: %s (%s)" % (request, self._objects)) + req = request + id = None + object = None + try: + id = req['id'] + if id: + id = int(id) + object = self._objects[id] + #_log("id, object: %d %s" % (id, object)) + except Exception, e: + #_log("Exception %s" % str(e)) + pass + if object is None or id is None: + id = None + object = self._export + #_log("found object %s" % str(object)) + + # Handle the request via a method with a special name on the server + handler_name = 'handle_%s' % request.action() + + try: + handler = getattr(self, handler_name) + except AttributeError: + raise BadRequest, request.action() + + response = handler(object, request) + + # figure out what to do with the response, and respond + # apprpriately. + if request.action() in ['status', 'type']: + # have to handle these specially since we want to + # pickle up the actual value and not return a proxy + self.respond(['value', response]) + elif callable(response): + #_log("callable %s" % response) + self.respond(['callable']) + elif self.is_value(response): + self.respond(['value', response]) + else: + self._objects[self._next_id] = response + #_log("objects: %s" % str(self._objects)) + self.respond(['object', self._next_id]) + self._next_id += 1 + except SystemExit, e: + raise e + except Exception, e: + self.write_exception(e) + except: + self.write_exception(sys.exc_info()[0]) + + def is_value(self, value): + """\ +@brief Test if value should be serialized as a simple dataset. +@param value The value to test. +@return Returns true if value is a simple serializeable set of data. +""" + return type(value) in (str,int,float,long,bool,type(None)) + + def respond(self, body): + _log("responding with: %s" % body) + #_log("objects: %s" % self._objects) + s = cPickle.dumps(body) + _log(`s`) + str = _write_lp_hunk(self._out, s) + + def write_exception(self, e): + """@brief Helper method to respond with an exception.""" + #_log("exception: %s" % sys.exc_info()[0]) + # TODO: serialize traceback using generalization of code from mulib.htmlexception + self.respond(['exception', e]) + global _g_debug_mode + if _g_debug_mode: + _log("traceback: %s" % traceback.format_tb(sys.exc_info()[2])) + + +# test function used for testing that final except clause +def raise_a_weird_error(): + raise "oh noes you can raise a string" + +# test function used for testing return of unpicklable exceptions +def raise_an_unpicklable_error(): + class Unpicklable(Exception): + pass + raise Unpicklable() + +# test function used for testing return of picklable exceptions +def raise_standard_error(): + raise FloatingPointError() + +# test function to make sure print doesn't break the wrapper +def print_string(str): + print str + +# test function to make sure printing on stdout doesn't break the +# wrapper +def err_string(str): + print >>sys.stderr, str + +def main(): + import optparse + parser = optparse.OptionParser( + usage="usage: %prog [options]", + description="Simple saranwrap.Server wrapper") + parser.add_option( + '-c', '--child', default=False, action='store_true', + help='Wrap an object serialed via setattr.') + parser.add_option( + '-m', '--module', type='string', dest='module', default=None, + help='a module to load and export.') + parser.add_option( + '-l', '--logfile', type='string', dest='logfile', default=None, + help='file to log to.') + options, args = parser.parse_args() + global _g_logfile + if options.logfile: + _g_logfile = open(options.logfile, 'a') + if options.module: + export = api.named(options.module) + server = Server(sys.stdin, sys.stdout, export) + elif options.child: + server = Server(sys.stdin, sys.stdout, {}) + + # *HACK: some modules may emit on stderr, which breaks everything. + class NullSTDOut(object): + def write(a, b): + pass + sys.stderr = NullSTDOut() + sys.stdout = NullSTDOut() + + # Loop until EOF + server.loop() + if _g_logfile: + _g_logfile.close() + + +if __name__ == "__main__": + main() diff --git a/linden/indra/lib/python/indra/ipc/servicebuilder.py b/linden/indra/lib/python/indra/ipc/servicebuilder.py new file mode 100644 index 0000000..ebd2583 --- /dev/null +++ b/linden/indra/lib/python/indra/ipc/servicebuilder.py @@ -0,0 +1,93 @@ +"""\ +@file servicebuilder.py +@author Phoenix +@brief Class which will generate service urls. + +$LicenseInfo:firstyear=2007&license=mit$ + +Copyright (c) 2007, Linden Research, Inc. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. +$/LicenseInfo$ +""" + +from indra.base import config +from indra.ipc import llsdhttp +from indra.ipc import russ + +# *NOTE: agent presence relies on this variable existing and being current, it is a huge hack +services_config = {} +try: + services_config = llsdhttp.get(config.get('services-config')) +except: + pass + +_g_builder = None +def build(name, context={}, **kwargs): + """ Convenience method for using a global, singleton, service builder. Pass arguments either via a dict or via python keyword arguments, or both! + + Example use: + > context = {'channel':'Second Life Release', 'version':'1.18.2.0'} + > servicebuilder.build('version-manager-version', context) + 'http://int.util.vaak.lindenlab.com/channel/Second%20Life%20Release/1.18.2.0' + > servicebuilder.build('version-manager-version', channel='Second Life Release', version='1.18.2.0') + 'http://int.util.vaak.lindenlab.com/channel/Second%20Life%20Release/1.18.2.0' + > servicebuilder.build('version-manager-version', context, version='1.18.1.2') + 'http://int.util.vaak.lindenlab.com/channel/Second%20Life%20Release/1.18.1.2' + """ + context = context.copy() # shouldn't modify the caller's dictionary + context.update(kwargs) + global _g_builder + if _g_builder is None: + _g_builder = ServiceBuilder() + return _g_builder.buildServiceURL(name, context) + +class ServiceBuilder(object): + def __init__(self, services_definition = services_config): + """\ + @brief + @brief Create a ServiceBuilder. + @param services_definition Complete services definition, services.xml. + """ + # no need to keep a copy of the services section of the + # complete services definition, but it doesn't hurt much. + self.services = services_definition['services'] + self.builders = {} + for service in self.services: + service_builder = service.get('service-builder') + if not service_builder: + continue + if isinstance(service_builder, dict): + # We will be constructing several builders + for name, builder in service_builder.items(): + full_builder_name = service['name'] + '-' + name + self.builders[full_builder_name] = builder + else: + self.builders[service['name']] = service_builder + + def buildServiceURL(self, name, context): + """\ + @brief given the environment on construction, return a service URL. + @param name The name of the service. + @param context A dict of name value lookups for the service. + @returns Returns the + """ + base_url = config.get('services-base-url') + svc_path = russ.format(self.builders[name], context) + return base_url + svc_path diff --git a/linden/indra/lib/python/indra/ipc/tokenstream.py b/linden/indra/lib/python/indra/ipc/tokenstream.py index 83b087a..37896d3 100644 --- a/linden/indra/lib/python/indra/ipc/tokenstream.py +++ b/linden/indra/lib/python/indra/ipc/tokenstream.py @@ -2,28 +2,28 @@ @file tokenstream.py @brief Message template parsing utility class +$LicenseInfo:firstyear=2007&license=mit$ + Copyright (c) 2007, Linden Research, Inc. -# Second Life Viewer Source Code -# The source code in this file ("Source Code") is provided by Linden Lab -# to you under the terms of the GNU General Public License, version 2.0 -# ("GPL"), unless you have obtained a separate licensing agreement -# ("Other License"), formally executed by you and Linden Lab. Terms of -# the GPL can be found in doc/GPL-license.txt in this distribution, or -# online at http://secondlife.com/developers/opensource/gplv2 -# -# There are special exceptions to the terms and conditions of the GPL as -# it is applied to this Source Code. View the full text of the exception -# in the file doc/FLOSS-exception.txt in this software distribution, or -# online at http://secondlife.com/developers/opensource/flossexception -# -# By copying, modifying or distributing this software, you acknowledge -# that you have read and understood your obligations described above, -# and agree to abide by those obligations. -# -# ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO -# WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, -# COMPLETENESS OR PERFORMANCE. +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. +$/LicenseInfo$ """ import re diff --git a/linden/indra/lib/python/indra/ipc/webdav.py b/linden/indra/lib/python/indra/ipc/webdav.py new file mode 100644 index 0000000..66e55ca --- /dev/null +++ b/linden/indra/lib/python/indra/ipc/webdav.py @@ -0,0 +1,597 @@ +""" +@file webdav.py +@brief Classes to make manipulation of a webdav store easier. + +$LicenseInfo:firstyear=2007&license=mit$ + +Copyright (c) 2007, Linden Research, Inc. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. +$/LicenseInfo$ +""" + +import sys, os, httplib, urlparse +import socket, time +import xml.dom.minidom +import syslog +# import signal + +__revision__ = '0' + +dav_debug = False + + +# def urlsafe_b64decode (enc): +# return base64.decodestring (enc.replace ('_', '/').replace ('-', '+')) + +# def urlsafe_b64encode (str): +# return base64.encodestring (str).replace ('+', '-').replace ('/', '_') + + +class DAVError (Exception): + """ Base class for exceptions in this module. """ + def __init__ (self, status=0, message='', body='', details=''): + self.status = status + self.message = message + self.body = body + self.details = details + Exception.__init__ (self, '%d:%s:%s%s' % (self.status, self.message, + self.body, self.details)) + + def print_to_stderr (self): + """ print_to_stderr docstring """ + print >> sys.stderr, str (self.status) + ' ' + self.message + print >> sys.stderr, str (self.details) + + +class Timeout (Exception): + """ Timeout docstring """ + def __init__ (self, arg=''): + Exception.__init__ (self, arg) + + +def alarm_handler (signum, frame): + """ alarm_handler docstring """ + raise Timeout ('caught alarm') + + +class WebDAV: + """ WebDAV docstring """ + def __init__ (self, url, proxy=None, retries_before_fail=6): + self.init_url = url + self.init_proxy = proxy + self.retries_before_fail = retries_before_fail + url_parsed = urlparse.urlsplit (url) + + self.top_path = url_parsed[ 2 ] + # make sure top_path has a trailing / + if self.top_path == None or self.top_path == '': + self.top_path = '/' + elif len (self.top_path) > 1 and self.top_path[-1:] != '/': + self.top_path += '/' + + if dav_debug: + syslog.syslog ('new WebDAV %s : %s' % (str (url), str (proxy))) + + if proxy: + proxy_parsed = urlparse.urlsplit (proxy) + self.host_header = url_parsed[ 1 ] + host_and_port = proxy_parsed[ 1 ].split (':') + self.host = host_and_port[ 0 ] + if len (host_and_port) > 1: + self.port = int(host_and_port[ 1 ]) + else: + self.port = 80 + else: # no proxy + host_and_port = url_parsed[ 1 ].split (':') + self.host_header = None + self.host = host_and_port[ 0 ] + if len (host_and_port) > 1: + self.port = int(host_and_port[ 1 ]) + else: + self.port = 80 + + self.connection = False + self.connect () + + + def log (self, msg, depth=0): + """ log docstring """ + if dav_debug and depth == 0: + host = str (self.init_url) + if host == 'http://int.tuco.lindenlab.com:80/asset/': + host = 'tuco' + if host == 'http://harriet.lindenlab.com/asset-keep/': + host = 'harriet/asset-keep' + if host == 'http://harriet.lindenlab.com/asset-flag/': + host = 'harriet/asset-flag' + if host == 'http://harriet.lindenlab.com/asset/': + host = 'harriet/asset' + if host == 'http://ozzy.lindenlab.com/asset/': + host = 'ozzy/asset' + if host == 'http://station11.lindenlab.com:12041/:': + host = 'station11:12041' + proxy = str (self.init_proxy) + if proxy == 'None': + proxy = '' + if proxy == 'http://int.tuco.lindenlab.com:3128/': + proxy = 'tuco' + syslog.syslog ('WebDAV (%s:%s) %s' % (host, proxy, str (msg))) + + + def connect (self): + """ connect docstring """ + self.log ('connect') + self.connection = httplib.HTTPConnection (self.host, self.port) + + def __err (self, response, details): + """ __err docstring """ + raise DAVError (response.status, response.reason, response.read (), + str (self.init_url) + ':' + \ + str (self.init_proxy) + ':' + str (details)) + + def request (self, method, path, body=None, headers=None, + read_all=True, body_hook = None, recurse=0, allow_cache=True): + """ request docstring """ + # self.log ('request %s %s' % (method, path)) + if headers == None: + headers = {} + if not allow_cache: + headers['Pragma'] = 'no-cache' + headers['cache-control'] = 'no-cache' + try: + if method.lower () != 'purge': + if path.startswith ('/'): + path = path[1:] + if self.host_header: # use proxy + headers[ 'host' ] = self.host_header + fullpath = 'http://%s%s%s' % (self.host_header, + self.top_path, path) + else: # no proxy + fullpath = self.top_path + path + else: + fullpath = path + + self.connection.request (method, fullpath, body, headers) + if body_hook: + body_hook () + + # signal.signal (signal.SIGALRM, alarm_handler) + # try: + # signal.alarm (120) + # signal.alarm (0) + # except Timeout, e: + # if recurse < 6: + # return self.retry_request (method, path, body, headers, + # read_all, body_hook, recurse) + # else: + # raise DAVError (0, 'timeout', self.host, + # (method, path, body, headers, recurse)) + + response = self.connection.getresponse () + + if read_all: + while len (response.read (1024)) > 0: + pass + if (response.status == 500 or \ + response.status == 503 or \ + response.status == 403) and \ + recurse < self.retries_before_fail: + return self.retry_request (method, path, body, headers, + read_all, body_hook, recurse) + return response + except (httplib.ResponseNotReady, + httplib.BadStatusLine, + socket.error): + # if the server hangs up on us (keepalive off, broken pipe), + # we need to reconnect and try again. + if recurse < self.retries_before_fail: + return self.retry_request (method, path, body, headers, + read_all, body_hook, recurse) + raise DAVError (0, 'reconnect failed', self.host, + (method, path, body, headers, recurse)) + + + def retry_request (self, method, path, body, headers, + read_all, body_hook, recurse): + """ retry_request docstring """ + time.sleep (10.0 * recurse) + self.connect () + return self.request (method, path, body, headers, + read_all, body_hook, recurse+1) + + + + def propfind (self, path, body=None, depth=1): + """ propfind docstring """ + # self.log ('propfind %s' % path) + headers = {'Content-Type':'text/xml; charset="utf-8"', + 'Depth':str(depth)} + response = self.request ('PROPFIND', path, body, headers, False) + if response.status == 207: + return response # Multi-Status + self.__err (response, ('PROPFIND', path, body, headers, 0)) + + + def purge (self, path): + """ issue a squid purge command """ + headers = {'Accept':'*/*'} + response = self.request ('PURGE', path, None, headers) + if response.status == 200 or response.status == 404: + # 200 if it was purge, 404 if it wasn't there. + return response + self.__err (response, ('PURGE', path, None, headers)) + + + def get_file_size (self, path): + """ + Use propfind to ask a webdav server what the size of + a file is. If used on a directory (collection) return 0 + """ + self.log ('get_file_size %s' % path) + # "getcontentlength" property + # 8.1.1 Example - Retrieving Named Properties + # http://docs.python.org/lib/module-xml.dom.html + nsurl = 'http://apache.org/dav/props/' + doc = xml.dom.minidom.Document () + propfind_element = doc.createElementNS (nsurl, "D:propfind") + propfind_element.setAttributeNS (nsurl, 'xmlns:D', 'DAV:') + doc.appendChild (propfind_element) + prop_element = doc.createElementNS (nsurl, "D:prop") + propfind_element.appendChild (prop_element) + con_len_element = doc.createElementNS (nsurl, "D:getcontentlength") + prop_element.appendChild (con_len_element) + + response = self.propfind (path, doc.toxml ()) + doc.unlink () + + resp_doc = xml.dom.minidom.parseString (response.read ()) + cln = resp_doc.getElementsByTagNameNS ('DAV:','getcontentlength')[ 0 ] + try: + content_length = int (cln.childNodes[ 0 ].nodeValue) + except IndexError: + return 0 + resp_doc.unlink () + return content_length + + + def file_exists (self, path): + """ + do an http head on the given file. return True if it succeeds + """ + self.log ('file_exists %s' % path) + expect_gzip = path.endswith ('.gz') + response = self.request ('HEAD', path) + got_gzip = response.getheader ('Content-Encoding', '').strip () + if got_gzip.lower () == 'x-gzip' and expect_gzip == False: + # the asset server fakes us out if we ask for the non-gzipped + # version of an asset, but the server has the gzipped version. + return False + return response.status == 200 + + + def mkdir (self, path): + """ mkdir docstring """ + self.log ('mkdir %s' % path) + headers = {} + response = self.request ('MKCOL', path, None, headers) + if response.status == 201: + return # success + if response.status == 405: + return # directory already existed? + self.__err (response, ('MKCOL', path, None, headers, 0)) + + + def delete (self, path): + """ delete docstring """ + self.log ('delete %s' % path) + headers = {'Depth':'infinity'} # collections require infinity + response = self.request ('DELETE', path, None, headers) + if response.status == 204: + return # no content + if response.status == 404: + return # hmm + self.__err (response, ('DELETE', path, None, headers, 0)) + + + def list_directory (self, path, dir_filter=None, allow_cache=True, + minimum_cache_time=False): + """ + Request an http directory listing and parse the filenames out of lines + like: '
  • X'. If a filter function is provided, + only return filenames that the filter returns True for. + + This is sort of grody, but it seems faster than other ways of getting + this information from an isilon. + """ + self.log ('list_directory %s' % path) + + def try_match (lline, before, after): + """ try_match docstring """ + try: + blen = len (before) + asset_start_index = lline.index (before) + asset_end_index = lline.index (after, asset_start_index + blen) + asset = line[ asset_start_index + blen : asset_end_index ] + + if not dir_filter or dir_filter (asset): + return [ asset ] + return [] + except ValueError: + return [] + + if len (path) > 0 and path[-1:] != '/': + path += '/' + + response = self.request ('GET', path, None, {}, False, + allow_cache=allow_cache) + + if allow_cache and minimum_cache_time: # XXX + print response.getheader ('Date') + # s = "2005-12-06T12:13:14" + # from datetime import datetime + # from time import strptime + # datetime(*strptime(s, "%Y-%m-%dT%H:%M:%S")[0:6]) + # datetime.datetime(2005, 12, 6, 12, 13, 14) + + if response.status != 200: + self.__err (response, ('GET', path, None, {}, 0)) + assets = [] + for line in response.read ().split ('\n'): + lline = line.lower () + if lline.find ("parent directory") == -1: + # isilon file + assets += try_match (lline, '
  • ') + # apache dir + assets += try_match (lline, 'alt="[dir]"> ') + # apache file + assets += try_match (lline, 'alt="[ ]"> ') + return assets + + + def __tmp_filename (self, path_and_file): + """ __tmp_filename docstring """ + head, tail = os.path.split (path_and_file) + if head != '': + return head + '/.' + tail + '.' + str (os.getpid ()) + else: + return head + '.' + tail + '.' + str (os.getpid ()) + + + def __put__ (self, filesize, body_hook, remotefile): + """ __put__ docstring """ + headers = {'Content-Length' : str (filesize)} + remotefile_tmp = self.__tmp_filename (remotefile) + response = self.request ('PUT', remotefile_tmp, None, + headers, True, body_hook) + if not response.status in (201, 204): # created, no content + self.__err (response, ('PUT', remotefile, None, headers, 0)) + if filesize != self.get_file_size (remotefile_tmp): + try: + self.delete (remotefile_tmp) + except: + pass + raise DAVError (0, 'tmp upload error', remotefile_tmp) + # move the file to its final location + try: + self.rename (remotefile_tmp, remotefile) + except DAVError, exc: + if exc.status == 403: # try to clean up the tmp file + try: + self.delete (remotefile_tmp) + except: + pass + raise + if filesize != self.get_file_size (remotefile): + raise DAVError (0, 'file upload error', str (remotefile_tmp)) + + + def put_string (self, strng, remotefile): + """ put_string docstring """ + self.log ('put_string %d -> %s' % (len (strng), remotefile)) + filesize = len (strng) + def body_hook (): + """ body_hook docstring """ + self.connection.send (strng) + self.__put__ (filesize, body_hook, remotefile) + + + def put_file (self, localfile, remotefile): + """ + Send a local file to a remote webdav store. First, upload to + a temporary filename. Next make sure the file is the size we + expected. Next, move the file to its final location. Next, + check the file size at the final location. + """ + self.log ('put_file %s -> %s' % (localfile, remotefile)) + filesize = os.path.getsize (localfile) + def body_hook (): + """ body_hook docstring """ + handle = open (localfile) + while True: + data = handle.read (1300) + if len (data) == 0: + break + self.connection.send (data) + handle.close () + self.__put__ (filesize, body_hook, remotefile) + + + def create_empty_file (self, remotefile): + """ create an empty file """ + self.log ('touch_file %s' % (remotefile)) + headers = {'Content-Length' : '0'} + response = self.request ('PUT', remotefile, None, headers) + if not response.status in (201, 204): # created, no content + self.__err (response, ('PUT', remotefile, None, headers, 0)) + if self.get_file_size (remotefile) != 0: + raise DAVError (0, 'file upload error', str (remotefile)) + + + def __get_file_setup (self, remotefile, check_size=True): + """ __get_file_setup docstring """ + if check_size: + remotesize = self.get_file_size (remotefile) + response = self.request ('GET', remotefile, None, {}, False) + if response.status != 200: + self.__err (response, ('GET', remotefile, None, {}, 0)) + try: + content_length = int (response.getheader ("Content-Length")) + except TypeError: + content_length = None + if check_size: + if content_length != remotesize: + raise DAVError (0, 'file DL size error', remotefile) + return (response, content_length) + + + def __get_file_read (self, writehandle, response, content_length): + """ __get_file_read docstring """ + if content_length != None: + so_far_length = 0 + while so_far_length < content_length: + data = response.read (content_length - so_far_length) + if len (data) == 0: + raise DAVError (0, 'short file download') + so_far_length += len (data) + writehandle.write (data) + while len (response.read ()) > 0: + pass + else: + while True: + data = response.read () + if (len (data) < 1): + break + writehandle.write (data) + + + def get_file (self, remotefile, localfile, check_size=True): + """ + Get a remote file from a webdav server. Download to a local + tmp file, then move into place. Sanity check file sizes as + we go. + """ + self.log ('get_file %s -> %s' % (remotefile, localfile)) + (response, content_length) = \ + self.__get_file_setup (remotefile, check_size) + localfile_tmp = self.__tmp_filename (localfile) + handle = open (localfile_tmp, 'w') + self.__get_file_read (handle, response, content_length) + handle.close () + if check_size: + if content_length != os.path.getsize (localfile_tmp): + raise DAVError (0, 'file DL size error', + remotefile+','+localfile) + os.rename (localfile_tmp, localfile) + + + def get_file_as_string (self, remotefile, check_size=True): + """ + download a file from a webdav server and return it as a string. + """ + self.log ('get_file_as_string %s' % remotefile) + (response, content_length) = \ + self.__get_file_setup (remotefile, check_size) + # (tmp_handle, tmp_filename) = tempfile.mkstemp () + tmp_handle = os.tmpfile () + self.__get_file_read (tmp_handle, response, content_length) + tmp_handle.seek (0) + ret = tmp_handle.read () + tmp_handle.close () + # os.unlink (tmp_filename) + return ret + + + def get_post_as_string (self, remotefile, body): + """ + Do an http POST, send body, get response and return it. + """ + self.log ('get_post_as_string %s' % remotefile) + # headers = {'Content-Type':'application/x-www-form-urlencoded'} + headers = {'Content-Type':'text/xml; charset="utf-8"'} + # b64body = urlsafe_b64encode (asset_url) + response = self.request ('POST', remotefile, body, headers, False) + if response.status != 200: + self.__err (response, ('POST', remotefile, body, headers, 0)) + try: + content_length = int (response.getheader ('Content-Length')) + except TypeError: + content_length = None + tmp_handle = os.tmpfile () + self.__get_file_read (tmp_handle, response, content_length) + tmp_handle.seek (0) + ret = tmp_handle.read () + tmp_handle.close () + return ret + + + def __destination_command (self, verb, remotesrc, dstdav, remotedst): + """ + self and dstdav should point to the same http server. + """ + if len (remotedst) > 0 and remotedst[ 0 ] == '/': + remotedst = remotedst[1:] + headers = {'Destination': 'http://%s:%d%s%s' % (dstdav.host, + dstdav.port, + dstdav.top_path, + remotedst)} + response = self.request (verb, remotesrc, None, headers) + if response.status == 201: + return # created + if response.status == 204: + return # no content + self.__err (response, (verb, remotesrc, None, headers, 0)) + + + def rename (self, remotesrc, remotedst): + """ rename a file on a webdav server """ + self.log ('rename %s -> %s' % (remotesrc, remotedst)) + self.__destination_command ('MOVE', remotesrc, self, remotedst) + def xrename (self, remotesrc, dstdav, remotedst): + """ rename a file on a webdav server """ + self.log ('xrename %s -> %s' % (remotesrc, remotedst)) + self.__destination_command ('MOVE', remotesrc, dstdav, remotedst) + + + def copy (self, remotesrc, remotedst): + """ copy a file on a webdav server """ + self.log ('copy %s -> %s' % (remotesrc, remotedst)) + self.__destination_command ('COPY', remotesrc, self, remotedst) + def xcopy (self, remotesrc, dstdav, remotedst): + """ copy a file on a webdav server """ + self.log ('xcopy %s -> %s' % (remotesrc, remotedst)) + self.__destination_command ('COPY', remotesrc, dstdav, remotedst) + + +def put_string (data, url): + """ + upload string s to a url + """ + url_parsed = urlparse.urlsplit (url) + dav = WebDAV ('%s://%s/' % (url_parsed[ 0 ], url_parsed[ 1 ])) + dav.put_string (data, url_parsed[ 2 ]) + + +def get_string (url, check_size=True): + """ + return the contents of a url as a string + """ + url_parsed = urlparse.urlsplit (url) + dav = WebDAV ('%s://%s/' % (url_parsed[ 0 ], url_parsed[ 1 ])) + return dav.get_file_as_string (url_parsed[ 2 ], check_size) diff --git a/linden/indra/lib/python/indra/ipc/xml_rpc.py b/linden/indra/lib/python/indra/ipc/xml_rpc.py new file mode 100644 index 0000000..dc8f0aa --- /dev/null +++ b/linden/indra/lib/python/indra/ipc/xml_rpc.py @@ -0,0 +1,273 @@ +"""\ +@file xml_rpc.py +@brief An implementation of a parser/generator for the XML-RPC xml format. + +$LicenseInfo:firstyear=2006&license=mit$ + +Copyright (c) 2006-2007, Linden Research, Inc. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. +$/LicenseInfo$ +""" + + +from greenlet import greenlet + +from mulib import mu + +from xml.sax import handler +from xml.sax import parseString + + +# States +class Expected(object): + def __init__(self, tag): + self.tag = tag + + def __getattr__(self, name): + return type(self)(name) + + def __repr__(self): + return '%s(%r)' % ( + type(self).__name__, self.tag) + + +class START(Expected): + pass + + +class END(Expected): + pass + + +class STR(object): + tag = '' + + +START = START('') +END = END('') + + +class Malformed(Exception): + pass + + +class XMLParser(handler.ContentHandler): + def __init__(self, state_machine, next_states): + handler.ContentHandler.__init__(self) + self.state_machine = state_machine + if not isinstance(next_states, tuple): + next_states = (next_states, ) + self.next_states = next_states + self._character_buffer = '' + + def assertState(self, state, name, *rest): + if not isinstance(self.next_states, tuple): + self.next_states = (self.next_states, ) + for next in self.next_states: + if type(state) == type(next): + if next.tag and next.tag != name: + raise Malformed( + "Expected %s, got %s %s %s" % ( + next, state, name, rest)) + break + else: + raise Malformed( + "Expected %s, got %s %s %s" % ( + self.next_states, state, name, rest)) + + def startElement(self, name, attrs): + self.assertState(START, name.lower(), attrs) + self.next_states = self.state_machine.switch(START, (name.lower(), dict(attrs))) + + def endElement(self, name): + if self._character_buffer.strip(): + characters = self._character_buffer.strip() + self._character_buffer = '' + self.assertState(STR, characters) + self.next_states = self.state_machine.switch(characters) + self.assertState(END, name.lower()) + self.next_states = self.state_machine.switch(END, name.lower()) + + def error(self, exc): + self.bozo = 1 + self.exc = exc + + def fatalError(self, exc): + self.error(exc) + raise exc + + def characters(self, characters): + self._character_buffer += characters + + +def parse(what): + child = greenlet(xml_rpc) + me = greenlet.getcurrent() + startup_states = child.switch(me) + parser = XMLParser(child, startup_states) + try: + parseString(what, parser) + except Malformed: + print what + raise + return child.switch() + + +def xml_rpc(yielder): + yielder.switch(START.methodcall) + yielder.switch(START.methodname) + methodName = yielder.switch(STR) + yielder.switch(END.methodname) + + yielder.switch(START.params) + + root = None + params = [] + while True: + state, _ = yielder.switch(START.param, END.params) + if state == END: + break + + yielder.switch(START.value) + + params.append( + handle(yielder)) + + yielder.switch(END.value) + yielder.switch(END.param) + + yielder.switch(END.methodcall) + ## Resume parse + yielder.switch() + ## Return result to parse + return methodName.strip(), params + + +def handle(yielder): + _, (tag, attrs) = yielder.switch(START) + if tag in ['int', 'i4']: + result = int(yielder.switch(STR)) + elif tag == 'boolean': + result = bool(int(yielder.switch(STR))) + elif tag == 'string': + result = yielder.switch(STR) + elif tag == 'double': + result = float(yielder.switch(STR)) + elif tag == 'datetime.iso8601': + result = yielder.switch(STR) + elif tag == 'base64': + result = base64.b64decode(yielder.switch(STR)) + elif tag == 'struct': + result = {} + while True: + state, _ = yielder.switch(START.member, END.struct) + if state == END: + break + + yielder.switch(START.name) + key = yielder.switch(STR) + yielder.switch(END.name) + + yielder.switch(START.value) + result[key] = handle(yielder) + yielder.switch(END.value) + + yielder.switch(END.member) + ## We already handled above, don't want to handle it below + return result + elif tag == 'array': + result = [] + yielder.switch(START.data) + while True: + state, _ = yielder.switch(START.value, END.data) + if state == END: + break + + result.append(handle(yielder)) + + yielder.switch(END.value) + + yielder.switch(getattr(END, tag)) + + return result + + +VALUE = mu.tag_factory('value') +BOOLEAN = mu.tag_factory('boolean') +INT = mu.tag_factory('int') +STRUCT = mu.tag_factory('struct') +MEMBER = mu.tag_factory('member') +NAME = mu.tag_factory('name') +ARRAY = mu.tag_factory('array') +DATA = mu.tag_factory('data') +STRING = mu.tag_factory('string') +DOUBLE = mu.tag_factory('double') +METHODRESPONSE = mu.tag_factory('methodResponse') +PARAMS = mu.tag_factory('params') +PARAM = mu.tag_factory('param') + +mu.inline_elements['string'] = True +mu.inline_elements['boolean'] = True +mu.inline_elements['name'] = True + + +def _generate(something): + if isinstance(something, dict): + result = STRUCT() + for key, value in something.items(): + result[ + MEMBER[ + NAME[key], _generate(value)]] + return VALUE[result] + elif isinstance(something, list): + result = DATA() + for item in something: + result[_generate(item)] + return VALUE[ARRAY[[result]]] + elif isinstance(something, basestring): + return VALUE[STRING[something]] + elif isinstance(something, bool): + if something: + return VALUE[BOOLEAN['1']] + return VALUE[BOOLEAN['0']] + elif isinstance(something, int): + return VALUE[INT[something]] + elif isinstance(something, float): + return VALUE[DOUBLE[something]] + +def generate(*args): + params = PARAMS() + for arg in args: + params[PARAM[_generate(arg)]] + return METHODRESPONSE[params] + + +if __name__ == '__main__': + print parse(""" examples.getStateName 41 +""") + + + + + + + + + diff --git a/linden/indra/lib/python/indra/util/__init__.py b/linden/indra/lib/python/indra/util/__init__.py index 3f79d0a..3eda184 100644 --- a/linden/indra/lib/python/indra/util/__init__.py +++ b/linden/indra/lib/python/indra/util/__init__.py @@ -2,26 +2,26 @@ @file __init__.py @brief Initialization file for the indra util module. +$LicenseInfo:firstyear=2006&license=mit$ + Copyright (c) 2006-2007, Linden Research, Inc. -# Second Life Viewer Source Code -# The source code in this file ("Source Code") is provided by Linden Lab -# to you under the terms of the GNU General Public License, version 2.0 -# ("GPL"), unless you have obtained a separate licensing agreement -# ("Other License"), formally executed by you and Linden Lab. Terms of -# the GPL can be found in doc/GPL-license.txt in this distribution, or -# online at http://secondlife.com/developers/opensource/gplv2 -# -# There are special exceptions to the terms and conditions of the GPL as -# it is applied to this Source Code. View the full text of the exception -# in the file doc/FLOSS-exception.txt in this software distribution, or -# online at http://secondlife.com/developers/opensource/flossexception -# -# By copying, modifying or distributing this software, you acknowledge -# that you have read and understood your obligations described above, -# and agree to abide by those obligations. -# -# ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO -# WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, -# COMPLETENESS OR PERFORMANCE. +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. +$/LicenseInfo$ """ diff --git a/linden/indra/lib/python/indra/util/helpformatter.py b/linden/indra/lib/python/indra/util/helpformatter.py new file mode 100644 index 0000000..c4ff27f --- /dev/null +++ b/linden/indra/lib/python/indra/util/helpformatter.py @@ -0,0 +1,52 @@ +"""\ +@file helpformatter.py +@author Phoenix +@brief Class for formatting optparse descriptions. + +$LicenseInfo:firstyear=2007&license=mit$ + +Copyright (c) 2007, Linden Research, Inc. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. +$/LicenseInfo$ +""" + +import optparse +import textwrap + +class Formatter(optparse.IndentedHelpFormatter): + def __init__( + self, + p_indentIncrement = 2, + p_maxHelpPosition = 24, + p_width = 79, + p_shortFirst = 1) : + optparse.HelpFormatter.__init__( + self, + p_indentIncrement, + p_maxHelpPosition, + p_width, + p_shortFirst) + def format_description(self, p_description): + t_descWidth = self.width - self.current_indent + t_indent = " " * (self.current_indent + 2) + return "\n".join( + [textwrap.fill(descr, t_descWidth, initial_indent = t_indent, + subsequent_indent = t_indent) + for descr in p_description.split("\n")] ) diff --git a/linden/indra/lib/python/indra/util/llmanifest.py b/linden/indra/lib/python/indra/util/llmanifest.py index c496e95..029b697 100644 --- a/linden/indra/lib/python/indra/util/llmanifest.py +++ b/linden/indra/lib/python/indra/util/llmanifest.py @@ -3,28 +3,28 @@ @author Ryan Williams @brief Library for specifying operations on a set of files. +$LicenseInfo:firstyear=2007&license=mit$ + Copyright (c) 2007, Linden Research, Inc. -# Second Life Viewer Source Code -# The source code in this file ("Source Code") is provided by Linden Lab -# to you under the terms of the GNU General Public License, version 2.0 -# ("GPL"), unless you have obtained a separate licensing agreement -# ("Other License"), formally executed by you and Linden Lab. Terms of -# the GPL can be found in doc/GPL-license.txt in this distribution, or -# online at http://secondlife.com/developers/opensource/gplv2 -# -# There are special exceptions to the terms and conditions of the GPL as -# it is applied to this Source Code. View the full text of the exception -# in the file doc/FLOSS-exception.txt in this software distribution, or -# online at http://secondlife.com/developers/opensource/flossexception -# -# By copying, modifying or distributing this software, you acknowledge -# that you have read and understood your obligations described above, -# and agree to abide by those obligations. -# -# ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO -# WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, -# COMPLETENESS OR PERFORMANCE. +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. +$/LicenseInfo$ """ import commands diff --git a/linden/indra/lib/python/indra/util/llversion.py b/linden/indra/lib/python/indra/util/llversion.py new file mode 100644 index 0000000..5e699d5 --- /dev/null +++ b/linden/indra/lib/python/indra/util/llversion.py @@ -0,0 +1,95 @@ +"""@file llversion.py +@brief Utility for parsing llcommon/llversion${server}.h + for the version string and channel string + Utility that parses svn info for branch and revision + +$LicenseInfo:firstyear=2006&license=mit$ + +Copyright (c) 2006-2007, Linden Research, Inc. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. +$/LicenseInfo$ +""" + +import re, sys, os, commands + +# Methods for gathering version information from +# llversionviewer.h and llversionserver.h + +def get_src_root(): + indra_lib_python_indra_path = os.path.dirname(__file__) + return os.path.abspath(os.path.realpath(indra_lib_python_indra_path + "/../../../../../")) + +def get_version_file_contents(version_type): + filepath = get_src_root() + '/indra/llcommon/llversion%s.h' % version_type + file = open(filepath,"r") + file_str = file.read() + file.close() + return file_str + +def get_version(version_type): + file_str = get_version_file_contents(version_type) + m = re.search('const S32 LL_VERSION_MAJOR = (\d+);', file_str) + VER_MAJOR = m.group(1) + m = re.search('const S32 LL_VERSION_MINOR = (\d+);', file_str) + VER_MINOR = m.group(1) + m = re.search('const S32 LL_VERSION_PATCH = (\d+);', file_str) + VER_PATCH = m.group(1) + m = re.search('const S32 LL_VERSION_BUILD = (\d+);', file_str) + VER_BUILD = m.group(1) + version = "%(VER_MAJOR)s.%(VER_MINOR)s.%(VER_PATCH)s.%(VER_BUILD)s" % locals() + return version + +def get_channel(version_type): + file_str = get_version_file_contents(version_type) + m = re.search('const char \* const LL_CHANNEL = "(.+)";', file_str) + return m.group(1) + +def get_viewer_version(): + return get_version('viewer') + +def get_server_version(): + return get_version('server') + +def get_viewer_channel(): + return get_channel('viewer') + +def get_server_channel(): + return get_channel('server') + +# Methods for gathering subversion information +def get_svn_status_matching(regular_expression): + # Get the subversion info from the working source tree + status, output = commands.getstatusoutput('svn info %s' % get_src_root()) + m = regular_expression.search(output) + if not m: + print "Failed to parse svn info output, resultfollows:" + print output + raise Exception, "No matching svn status in "+src_root + return m.group(1) + +def get_svn_branch(): + branch_re = re.compile('URL: (\S+)') + return get_svn_status_matching(branch_re) + +def get_svn_revision(): + last_rev_re = re.compile('Last Changed Rev: (\d+)') + return get_svn_status_matching(last_rev_re) + + diff --git a/linden/indra/lib/python/indra/util/named_query.py b/linden/indra/lib/python/indra/util/named_query.py new file mode 100644 index 0000000..019eb63 --- /dev/null +++ b/linden/indra/lib/python/indra/util/named_query.py @@ -0,0 +1,215 @@ +"""\ +@file named_query.py +@author Ryan Williams, Phoenix +@date 2007-07-31 +@brief An API for running named queries. + +$LicenseInfo:firstyear=2007&license=mit$ + +Copyright (c) 2007, Linden Research, Inc. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. +$/LicenseInfo$ +""" + +import MySQLdb +import os +import os.path +import time + +from indra.base import llsd +from indra.base import config +from indra.ipc import russ + +_g_named_manager = None + +# this function is entirely intended for testing purposes, +# because it's tricky to control the config from inside a test +def _init_g_named_manager(sql_dir = None): + if sql_dir is None: + sql_dir = config.get('named-query-base-dir') + global _g_named_manager + _g_named_manager = NamedQueryManager( + os.path.abspath(os.path.realpath(sql_dir))) + +def get(name): + "@brief get the named query object to be used to perform queries" + if _g_named_manager is None: + _init_g_named_manager() + return _g_named_manager.get(name) + +def sql(name, params): + # use module-global NamedQuery object to perform default substitution + return get(name).sql(params) + +def run(connection, name, params, expect_rows = None): + """\ +@brief given a connection, run a named query with the params + +Note that this function will fetch ALL rows. +@param connection The connection to use +@param name The name of the query to run +@param params The parameters passed into the query +@param expect_rows The number of rows expected. Set to 1 if return_as_map is true. Raises ExpectationFailed if the number of returned rows doesn't exactly match. Kind of a hack. +@return Returns the result set as a list of dicts. +""" + return get(name).run(connection, params, expect_rows) + +class ExpectationFailed(Exception): + def __init__(self, message): + self.message = message + +class NamedQuery(object): + def __init__(self, name, filename): + self._stat_interval = 5000 # 5 seconds + self._name = name + self._location = filename + self.load_contents() + + def name(self): + return self._name + + def get_modtime(self): + return os.path.getmtime(self._location) + + def load_contents(self): + self._contents = llsd.parse(open(self._location).read()) + self._ttl = int(self._contents.get('ttl', 0)) + self._return_as_map = bool(self._contents.get('return_as_map', False)) + self._legacy_dbname = self._contents.get('legacy_dbname', None) + self._legacy_query = self._contents.get('legacy_query', None) + self._options = self._contents.get('options', {}) + self._base_query = self._contents['base_query'] + + self._last_mod_time = self.get_modtime() + self._last_check_time = time.time() + + def ttl(self): + return self._ttl + + def legacy_dbname(self): + return self._legacy_dbname + + def legacy_query(self): + return self._legacy_query + + def return_as_map(self): + return self._return_as_map + + def run(self, connection, params, expect_rows = None, use_dictcursor = True): + """\ +@brief given a connection, run a named query with the params + +Note that this function will fetch ALL rows. We do this because it +opens and closes the cursor to generate the values, and this isn't a generator so the +cursor has no life beyond the method call. +@param cursor The connection to use (this generates its own cursor for the query) +@param name The name of the query to run +@param params The parameters passed into the query +@param expect_rows The number of rows expected. Set to 1 if return_as_map is true. Raises ExpectationFailed if the number of returned rows doesn't exactly match. Kind of a hack. +@param use_dictcursor Set to false to use a normal cursor and manually convert the rows to dicts. +@return Returns the result set as a list of dicts, or, if the named query has return_as_map set to true, returns a single dict. + """ + if use_dictcursor: + cursor = connection.cursor(MySQLdb.cursors.DictCursor) + else: + cursor = connection.cursor() + + statement = self.sql(params) + #print "SQL:", statement + rows = cursor.execute(statement) + + # *NOTE: the expect_rows argument is a very cheesy way to get some + # validation on the result set. If you want to add more expectation + # logic, do something more object-oriented and flexible. Or use an ORM. + if(self._return_as_map): + expect_rows = 1 + if expect_rows is not None and rows != expect_rows: + cursor.close() + raise ExpectationFailed("Statement expected %s rows, got %s. Sql: %s" % ( + expect_rows, rows, statement)) + + # convert to dicts manually if we're not using a dictcursor + if use_dictcursor: + result_set = cursor.fetchall() + else: + if cursor.description is None: + # an insert or something + x = cursor.fetchall() + cursor.close() + return x + + names = [x[0] for x in cursor.description] + + result_set = [] + for row in cursor.fetchall(): + converted_row = {} + for idx, col_name in enumerate(names): + converted_row[col_name] = row[idx] + result_set.append(converted_row) + + cursor.close() + if self._return_as_map: + return result_set[0] + return result_set + + def sql(self, params): + self.refresh() + + # build the query from the options available and the params + base_query = [] + base_query.append(self._base_query) + for opt, extra_where in self._options.items(): + if opt in params and (params[opt] == 0 or params[opt]): + if type(extra_where) in (dict, list, tuple): + base_query.append(extra_where[params[opt]]) + else: + base_query.append(extra_where) + + full_query = '\n'.join(base_query) + + # do substitution + sql = russ.format(full_query, params) + return sql + + def refresh(self): + # only stat the file every so often + now = time.time() + if(now - self._last_check_time > self._stat_interval): + self._last_check_time = now + modtime = self.get_modtime() + if(modtime > self._last_mod_time): + self.load_contents() + +class NamedQueryManager(object): + def __init__(self, named_queries_dir): + self._dir = os.path.abspath(os.path.realpath(named_queries_dir)) + self._cached_queries = {} + + def sql(self, name, params): + nq = self.get(name) + return nq.sql(params) + + def get(self, name): + # new up/refresh a NamedQuery based on the name + nq = self._cached_queries.get(name) + if nq is None: + nq = NamedQuery(name, os.path.join(self._dir, name)) + self._cached_queries[name] = nq + return nq diff --git a/linden/indra/linux_crash_logger/linux_crash_logger.cpp b/linden/indra/linux_crash_logger/linux_crash_logger.cpp index f9c03b0..e75a317 100644 --- a/linden/indra/linux_crash_logger/linux_crash_logger.cpp +++ b/linden/indra/linux_crash_logger/linux_crash_logger.cpp @@ -2,6 +2,8 @@ * @file linux_crash_logger.cpp * @brief Linux crash logger implementation * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,13 +26,11 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" -#include -#include -#include #include #include #include diff --git a/linden/indra/llaudio/audioengine.cpp b/linden/indra/llaudio/audioengine.cpp index 373b0c1..afacea7 100644 --- a/linden/indra/llaudio/audioengine.cpp +++ b/linden/indra/llaudio/audioengine.cpp @@ -3,6 +3,8 @@ * @brief implementation of LLAudioEngine class abstracting the Open * AL audio support * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,21 +27,11 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" -#include -#include -#include -#include - -#if LL_LINUX || LL_SOLARIS -#include -#endif - -//#include "message.h" - #include "audioengine.h" #include "llerror.h" diff --git a/linden/indra/llaudio/audioengine.h b/linden/indra/llaudio/audioengine.h index 3b6bbd7..5a8176b 100644 --- a/linden/indra/llaudio/audioengine.h +++ b/linden/indra/llaudio/audioengine.h @@ -2,6 +2,8 @@ * @file audioengine.h * @brief Definition of LLAudioEngine base class abstracting the audio support * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ diff --git a/linden/indra/llaudio/audioengine_fmod.cpp b/linden/indra/llaudio/audioengine_fmod.cpp index 4574a57..0ee8344 100644 --- a/linden/indra/llaudio/audioengine_fmod.cpp +++ b/linden/indra/llaudio/audioengine_fmod.cpp @@ -3,6 +3,8 @@ * @brief Implementation of LLAudioEngine class abstracting the audio * support as a FMOD 3D implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,15 +27,11 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" -#include -#include -#include -#include - #include "audioengine_fmod.h" #if LL_FMOD diff --git a/linden/indra/llaudio/audioengine_fmod.h b/linden/indra/llaudio/audioengine_fmod.h index 6a40a12..29a7a14 100644 --- a/linden/indra/llaudio/audioengine_fmod.h +++ b/linden/indra/llaudio/audioengine_fmod.h @@ -3,6 +3,8 @@ * @brief Definition of LLAudioEngine class abstracting the audio * support as a FMOD 3D implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_AUDIOENGINE_FMOD_H diff --git a/linden/indra/llaudio/listener.cpp b/linden/indra/llaudio/listener.cpp index 3860949..d1922a5 100644 --- a/linden/indra/llaudio/listener.cpp +++ b/linden/indra/llaudio/listener.cpp @@ -2,6 +2,8 @@ * @file listener.cpp * @brief Implementation of LISTENER class abstracting the audio support * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llaudio/listener.h b/linden/indra/llaudio/listener.h index 5cf0ac6..bbd2f59 100644 --- a/linden/indra/llaudio/listener.h +++ b/linden/indra/llaudio/listener.h @@ -2,6 +2,8 @@ * @file listener.h * @brief Description of LISTENER base class abstracting the audio support. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,13 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LISTENER_H #define LL_LISTENER_H -#include - #include "v3math.h" class LLListener diff --git a/linden/indra/llaudio/listener_ds3d.h b/linden/indra/llaudio/listener_ds3d.h index 4859513..99215c9 100644 --- a/linden/indra/llaudio/listener_ds3d.h +++ b/linden/indra/llaudio/listener_ds3d.h @@ -3,6 +3,8 @@ * @brief Description of LISTENER class abstracting the audio support * as a DirectSound 3D implementation (windows only) * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LISTENER_DS3D_H diff --git a/linden/indra/llaudio/listener_fmod.cpp b/linden/indra/llaudio/listener_fmod.cpp index 36f9fcf..d215663 100644 --- a/linden/indra/llaudio/listener_fmod.cpp +++ b/linden/indra/llaudio/listener_fmod.cpp @@ -3,6 +3,8 @@ * @brief implementation of LISTENER class abstracting the audio * support as a FMOD 3D implementation (windows only) * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llaudio/listener_fmod.h b/linden/indra/llaudio/listener_fmod.h index e532371..be9f866 100644 --- a/linden/indra/llaudio/listener_fmod.h +++ b/linden/indra/llaudio/listener_fmod.h @@ -3,6 +3,8 @@ * @brief Description of LISTENER class abstracting the audio support * as an FMOD 3D implementation (windows and Linux) * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LISTENER_FMOD_H diff --git a/linden/indra/llaudio/listener_openal.h b/linden/indra/llaudio/listener_openal.h index 480c3fa..5d5a760 100644 --- a/linden/indra/llaudio/listener_openal.h +++ b/linden/indra/llaudio/listener_openal.h @@ -3,6 +3,8 @@ * @brief Description of LISTENER class abstracting the audio support * as an OpenAL implementation * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LISTENER_OPENAL_H diff --git a/linden/indra/llaudio/llaudiodecodemgr.cpp b/linden/indra/llaudio/llaudiodecodemgr.cpp index ffd115a..ed4feff 100644 --- a/linden/indra/llaudio/llaudiodecodemgr.cpp +++ b/linden/indra/llaudio/llaudiodecodemgr.cpp @@ -1,6 +1,8 @@ /** * @file llaudiodecodemgr.cpp * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,15 +25,11 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" -#include -#include -#include -#include - #include "llaudiodecodemgr.h" #include "vorbisdecode.h" diff --git a/linden/indra/llaudio/llaudiodecodemgr.h b/linden/indra/llaudio/llaudiodecodemgr.h index e01bb29..530f642 100644 --- a/linden/indra/llaudio/llaudiodecodemgr.h +++ b/linden/indra/llaudio/llaudiodecodemgr.h @@ -1,6 +1,8 @@ /** * @file llaudiodecodemgr.h * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLAUDIODECODEMGR_H diff --git a/linden/indra/llaudio/vorbisdecode.cpp b/linden/indra/llaudio/vorbisdecode.cpp index bb7a73d..0da107d 100644 --- a/linden/indra/llaudio/vorbisdecode.cpp +++ b/linden/indra/llaudio/vorbisdecode.cpp @@ -2,6 +2,8 @@ * @file vorbisdecode.cpp * @brief Vorbis decoding routine routine for Indra. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,14 +26,11 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" -#include -#include -#include - #include "vorbis/codec.h" #include "vorbis/vorbisfile.h" #include "llerror.h" diff --git a/linden/indra/llaudio/vorbisdecode.h b/linden/indra/llaudio/vorbisdecode.h index 16ee4ae..10e5f33 100644 --- a/linden/indra/llaudio/vorbisdecode.h +++ b/linden/indra/llaudio/vorbisdecode.h @@ -2,6 +2,8 @@ * @file vorbisdecode.h * @brief Vorbis decoding routine routine for Indra. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_VORBISDECODE_H diff --git a/linden/indra/llaudio/vorbisencode.cpp b/linden/indra/llaudio/vorbisencode.cpp index 6a0ebac..3bc8b1d 100644 --- a/linden/indra/llaudio/vorbisencode.cpp +++ b/linden/indra/llaudio/vorbisencode.cpp @@ -2,6 +2,8 @@ * @file vorbisencode.cpp * @brief Vorbis encoding routine routine for Indra. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,14 +26,11 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" -#include -#include -#include - #include "vorbisencode.h" #include "vorbis/vorbisenc.h" #include "llerror.h" diff --git a/linden/indra/llaudio/vorbisencode.h b/linden/indra/llaudio/vorbisencode.h index e7f76c3..d07d245 100644 --- a/linden/indra/llaudio/vorbisencode.h +++ b/linden/indra/llaudio/vorbisencode.h @@ -2,6 +2,8 @@ * @file vorbisencode.h * @brief Vorbis encoding routine routine for Indra. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_VORBISENCODE_H diff --git a/linden/indra/llcharacter/llanimationstates.cpp b/linden/indra/llcharacter/llanimationstates.cpp index 95aa5d6..3e5a1e6 100644 --- a/linden/indra/llcharacter/llanimationstates.cpp +++ b/linden/indra/llcharacter/llanimationstates.cpp @@ -2,6 +2,8 @@ * @file llanimationstates.cpp * @brief Implementation of animation state related functions. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- @@ -32,8 +35,6 @@ #include "linden_common.h" -#include - #include "llanimationstates.h" #include "llstring.h" diff --git a/linden/indra/llcharacter/llanimationstates.h b/linden/indra/llcharacter/llanimationstates.h index 6a9f7a4..cceb952 100644 --- a/linden/indra/llcharacter/llanimationstates.h +++ b/linden/indra/llcharacter/llanimationstates.h @@ -2,6 +2,8 @@ * @file llanimationstates.h * @brief Implementation of animation state support. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLANIMATIONSTATES_H diff --git a/linden/indra/llcharacter/llbvhloader.cpp b/linden/indra/llcharacter/llbvhloader.cpp index 9f7e901..1d157fd 100644 --- a/linden/indra/llcharacter/llbvhloader.cpp +++ b/linden/indra/llcharacter/llbvhloader.cpp @@ -2,6 +2,8 @@ * @file llbvhloader.cpp * @brief Translates a BVH files to LindenLabAnimation format. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,11 +26,15 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" #include "llbvhloader.h" + +#include + #include "lldatapacker.h" #include "lldir.h" #include "llkeyframemotion.h" @@ -36,11 +42,6 @@ #include "llstl.h" #include "llapr.h" -#include -#include -#include -#include -#include using namespace std; diff --git a/linden/indra/llcharacter/llbvhloader.h b/linden/indra/llcharacter/llbvhloader.h index 0a4f9a9..9f69cff 100644 --- a/linden/indra/llcharacter/llbvhloader.h +++ b/linden/indra/llcharacter/llbvhloader.h @@ -2,6 +2,8 @@ * @file llbvhloader.h * @brief Translates a BVH files to LindenLabAnimation format. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,16 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLBVHLOADER_H #define LL_LLBVHLOADER_H -#include -#include -#include -#include -#include #include "v3math.h" #include "m3math.h" #include "llmath.h" diff --git a/linden/indra/llcharacter/llcharacter.cpp b/linden/indra/llcharacter/llcharacter.cpp index 29872f7..ff05b25 100644 --- a/linden/indra/llcharacter/llcharacter.cpp +++ b/linden/indra/llcharacter/llcharacter.cpp @@ -2,6 +2,8 @@ * @file llcharacter.cpp * @brief Implementation of LLCharacter class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- diff --git a/linden/indra/llcharacter/llcharacter.h b/linden/indra/llcharacter/llcharacter.h index 666beb2..eb001d5 100644 --- a/linden/indra/llcharacter/llcharacter.h +++ b/linden/indra/llcharacter/llcharacter.h @@ -2,6 +2,8 @@ * @file llcharacter.h * @brief Implementation of LLCharacter class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCHARACTER_H diff --git a/linden/indra/llcharacter/lleditingmotion.cpp b/linden/indra/llcharacter/lleditingmotion.cpp index 08d7940..6e87842 100644 --- a/linden/indra/llcharacter/lleditingmotion.cpp +++ b/linden/indra/llcharacter/lleditingmotion.cpp @@ -2,6 +2,8 @@ * @file lleditingmotion.cpp * @brief Implementation of LLEditingMotion class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- diff --git a/linden/indra/llcharacter/lleditingmotion.h b/linden/indra/llcharacter/lleditingmotion.h index 6ca6765..18bfd7f 100644 --- a/linden/indra/llcharacter/lleditingmotion.h +++ b/linden/indra/llcharacter/lleditingmotion.h @@ -2,6 +2,8 @@ * @file lleditingmotion.h * @brief Implementation of LLEditingMotion class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLEDITINGMOTION_H diff --git a/linden/indra/llcharacter/llgesture.cpp b/linden/indra/llcharacter/llgesture.cpp index 231047d..ee23963 100644 --- a/linden/indra/llcharacter/llgesture.cpp +++ b/linden/indra/llcharacter/llgesture.cpp @@ -1,6 +1,8 @@ /** * @file llgesture.cpp * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcharacter/llgesture.h b/linden/indra/llcharacter/llgesture.h index dc2b10c..34fdcd0 100644 --- a/linden/indra/llcharacter/llgesture.h +++ b/linden/indra/llcharacter/llgesture.h @@ -3,6 +3,8 @@ * @brief A gesture is a combination of a triggering chat phrase or * key, a sound, an animation, and a chat string. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLGESTURE_H diff --git a/linden/indra/llcharacter/llhandmotion.cpp b/linden/indra/llcharacter/llhandmotion.cpp index 96b1dc7..511ccc7 100644 --- a/linden/indra/llcharacter/llhandmotion.cpp +++ b/linden/indra/llcharacter/llhandmotion.cpp @@ -2,6 +2,8 @@ * @file llhandmotion.cpp * @brief Implementation of LLHandMotion class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- diff --git a/linden/indra/llcharacter/llhandmotion.h b/linden/indra/llcharacter/llhandmotion.h index b909818..39c61b2 100644 --- a/linden/indra/llcharacter/llhandmotion.h +++ b/linden/indra/llcharacter/llhandmotion.h @@ -2,6 +2,8 @@ * @file llhandmotion.h * @brief Implementation of LLHandMotion class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLHANDMOTION_H diff --git a/linden/indra/llcharacter/llheadrotmotion.cpp b/linden/indra/llcharacter/llheadrotmotion.cpp index 73f8e8b..55af269 100644 --- a/linden/indra/llcharacter/llheadrotmotion.cpp +++ b/linden/indra/llcharacter/llheadrotmotion.cpp @@ -2,6 +2,8 @@ * @file llheadrotmotion.cpp * @brief Implementation of LLHeadRotMotion class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- diff --git a/linden/indra/llcharacter/llheadrotmotion.h b/linden/indra/llcharacter/llheadrotmotion.h index bdb82aa..efb9c3e 100644 --- a/linden/indra/llcharacter/llheadrotmotion.h +++ b/linden/indra/llcharacter/llheadrotmotion.h @@ -2,6 +2,8 @@ * @file llheadrotmotion.h * @brief Implementation of LLHeadRotMotion class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLHEADROTMOTION_H diff --git a/linden/indra/llcharacter/lljoint.cpp b/linden/indra/llcharacter/lljoint.cpp index 07c34a8..00ec8e5 100644 --- a/linden/indra/llcharacter/lljoint.cpp +++ b/linden/indra/llcharacter/lljoint.cpp @@ -2,6 +2,8 @@ * @file lljoint.cpp * @brief Implementation of LLJoint class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- diff --git a/linden/indra/llcharacter/lljoint.h b/linden/indra/llcharacter/lljoint.h index d1e0107..167598f 100644 --- a/linden/indra/llcharacter/lljoint.h +++ b/linden/indra/llcharacter/lljoint.h @@ -2,6 +2,8 @@ * @file lljoint.h * @brief Implementation of LLJoint class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLJOINT_H diff --git a/linden/indra/llcharacter/lljointsolverrp3.cpp b/linden/indra/llcharacter/lljointsolverrp3.cpp index 9ecb31b..0237f1e 100644 --- a/linden/indra/llcharacter/lljointsolverrp3.cpp +++ b/linden/indra/llcharacter/lljointsolverrp3.cpp @@ -2,6 +2,8 @@ * @file lljointsolverrp3.cpp * @brief Implementation of LLJointSolverRP3 class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- @@ -33,8 +36,6 @@ #include "lljointsolverrp3.h" -#include - #include "llmath.h" #define F_EPSILON 0.00001f diff --git a/linden/indra/llcharacter/lljointsolverrp3.h b/linden/indra/llcharacter/lljointsolverrp3.h index 42f4912..24d5b6c 100644 --- a/linden/indra/llcharacter/lljointsolverrp3.h +++ b/linden/indra/llcharacter/lljointsolverrp3.h @@ -2,6 +2,8 @@ * @file lljointsolverrp3.h * @brief Implementation of LLJointSolverRP3 class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLJOINTSOLVERRP3_H diff --git a/linden/indra/llcharacter/lljointstate.h b/linden/indra/llcharacter/lljointstate.h index 5311374..2022322 100644 --- a/linden/indra/llcharacter/lljointstate.h +++ b/linden/indra/llcharacter/lljointstate.h @@ -2,6 +2,8 @@ * @file lljointstate.h * @brief Implementation of LLJointState class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLJOINTSTATE_H diff --git a/linden/indra/llcharacter/llkeyframefallmotion.cpp b/linden/indra/llcharacter/llkeyframefallmotion.cpp index d539be6..bcef7a3 100644 --- a/linden/indra/llcharacter/llkeyframefallmotion.cpp +++ b/linden/indra/llcharacter/llkeyframefallmotion.cpp @@ -2,6 +2,8 @@ * @file llkeyframefallmotion.cpp * @brief Implementation of LLKeyframeFallMotion class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- diff --git a/linden/indra/llcharacter/llkeyframefallmotion.h b/linden/indra/llcharacter/llkeyframefallmotion.h index b6a4e68..4307c51 100644 --- a/linden/indra/llcharacter/llkeyframefallmotion.h +++ b/linden/indra/llcharacter/llkeyframefallmotion.h @@ -2,6 +2,8 @@ * @file llkeyframefallmotion.h * @brief Implementation of LLKeframeWalkMotion class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLKeyframeFallMotion_H diff --git a/linden/indra/llcharacter/llkeyframemotion.cpp b/linden/indra/llcharacter/llkeyframemotion.cpp index cf489aa..6efe243 100644 --- a/linden/indra/llcharacter/llkeyframemotion.cpp +++ b/linden/indra/llcharacter/llkeyframemotion.cpp @@ -2,6 +2,8 @@ * @file llkeyframemotion.cpp * @brief Implementation of LLKeyframeMotion class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- diff --git a/linden/indra/llcharacter/llkeyframemotion.h b/linden/indra/llcharacter/llkeyframemotion.h index 9e1b11d..57123fa 100644 --- a/linden/indra/llcharacter/llkeyframemotion.h +++ b/linden/indra/llcharacter/llkeyframemotion.h @@ -2,6 +2,8 @@ * @file llkeyframemotion.h * @brief Implementation of LLKeframeMotion class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLKEYFRAMEMOTION_H diff --git a/linden/indra/llcharacter/llkeyframemotionparam.cpp b/linden/indra/llcharacter/llkeyframemotionparam.cpp index d24b8a6..dd64ef2 100644 --- a/linden/indra/llcharacter/llkeyframemotionparam.cpp +++ b/linden/indra/llcharacter/llkeyframemotionparam.cpp @@ -2,6 +2,8 @@ * @file llkeyframemotionparam.cpp * @brief Implementation of LLKeyframeMotion class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- diff --git a/linden/indra/llcharacter/llkeyframemotionparam.h b/linden/indra/llcharacter/llkeyframemotionparam.h index e0885c1..204a475 100644 --- a/linden/indra/llcharacter/llkeyframemotionparam.h +++ b/linden/indra/llcharacter/llkeyframemotionparam.h @@ -2,6 +2,8 @@ * @file llkeyframemotionparam.h * @brief Implementation of LLKeframeMotionParam class. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLKEYFRAMEMOTIONPARAM_H diff --git a/linden/indra/llcharacter/llkeyframestandmotion.cpp b/linden/indra/llcharacter/llkeyframestandmotion.cpp index 9b423c5..5093243 100644 --- a/linden/indra/llcharacter/llkeyframestandmotion.cpp +++ b/linden/indra/llcharacter/llkeyframestandmotion.cpp @@ -2,6 +2,8 @@ * @file llkeyframestandmotion.cpp * @brief Implementation of LLKeyframeStandMotion class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- diff --git a/linden/indra/llcharacter/llkeyframestandmotion.h b/linden/indra/llcharacter/llkeyframestandmotion.h index e7c54c5..48496af 100644 --- a/linden/indra/llcharacter/llkeyframestandmotion.h +++ b/linden/indra/llcharacter/llkeyframestandmotion.h @@ -2,6 +2,8 @@ * @file llkeyframestandmotion.h * @brief Implementation of LLKeyframeStandMotion class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLKEYFRAMESTANDMOTION_H diff --git a/linden/indra/llcharacter/llkeyframewalkmotion.cpp b/linden/indra/llcharacter/llkeyframewalkmotion.cpp index bf347a6..9a49996 100644 --- a/linden/indra/llcharacter/llkeyframewalkmotion.cpp +++ b/linden/indra/llcharacter/llkeyframewalkmotion.cpp @@ -2,6 +2,8 @@ * @file llkeyframewalkmotion.cpp * @brief Implementation of LLKeyframeWalkMotion class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- diff --git a/linden/indra/llcharacter/llkeyframewalkmotion.h b/linden/indra/llcharacter/llkeyframewalkmotion.h index d2c9cd8..f52a8d6 100644 --- a/linden/indra/llcharacter/llkeyframewalkmotion.h +++ b/linden/indra/llcharacter/llkeyframewalkmotion.h @@ -2,6 +2,8 @@ * @file llkeyframewalkmotion.h * @brief Implementation of LLKeframeWalkMotion class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLKEYFRAMEWALKMOTION_H diff --git a/linden/indra/llcharacter/llmotion.cpp b/linden/indra/llcharacter/llmotion.cpp index 40a30a4..e674620 100644 --- a/linden/indra/llcharacter/llmotion.cpp +++ b/linden/indra/llcharacter/llmotion.cpp @@ -2,6 +2,8 @@ * @file llmotion.cpp * @brief Implementation of LLMotion class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- diff --git a/linden/indra/llcharacter/llmotion.h b/linden/indra/llcharacter/llmotion.h index e60b0c0..2b5c5aa 100644 --- a/linden/indra/llcharacter/llmotion.h +++ b/linden/indra/llcharacter/llmotion.h @@ -2,6 +2,8 @@ * @file llmotion.h * @brief Implementation of LLMotion class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMOTION_H diff --git a/linden/indra/llcharacter/llmotioncontroller.cpp b/linden/indra/llcharacter/llmotioncontroller.cpp index aebfaf6..603ee6a 100644 --- a/linden/indra/llcharacter/llmotioncontroller.cpp +++ b/linden/indra/llcharacter/llmotioncontroller.cpp @@ -2,6 +2,8 @@ * @file llmotioncontroller.cpp * @brief Implementation of LLMotionController class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- @@ -763,6 +766,10 @@ void LLMotionController::updateMotion() { motion_set_t::iterator curiter = iter++; LLMotion* motionp = *curiter; + if( !motionp) + { + continue; // maybe shouldn't happen but i've seen it -MG + } LLMotion::LLMotionInitStatus status = motionp->onInitialize(mCharacter); if (status == LLMotion::STATUS_SUCCESS) { diff --git a/linden/indra/llcharacter/llmotioncontroller.h b/linden/indra/llcharacter/llmotioncontroller.h index efc12d5..63c9219 100644 --- a/linden/indra/llcharacter/llmotioncontroller.h +++ b/linden/indra/llcharacter/llmotioncontroller.h @@ -2,6 +2,8 @@ * @file llmotioncontroller.h * @brief Implementation of LLMotionController class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMOTIONCONTROLLER_H diff --git a/linden/indra/llcharacter/llmultigesture.cpp b/linden/indra/llcharacter/llmultigesture.cpp index e92fcbd..d8db060 100644 --- a/linden/indra/llcharacter/llmultigesture.cpp +++ b/linden/indra/llcharacter/llmultigesture.cpp @@ -2,6 +2,8 @@ * @file llmultigesture.cpp * @brief Gestures that are asset-based and can have multiple steps. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcharacter/llmultigesture.h b/linden/indra/llcharacter/llmultigesture.h index 75e5db8..84ca641 100644 --- a/linden/indra/llcharacter/llmultigesture.h +++ b/linden/indra/llcharacter/llmultigesture.h @@ -2,6 +2,8 @@ * @file llmultigesture.h * @brief Gestures that are asset-based and can have multiple steps. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMULTIGESTURE_H diff --git a/linden/indra/llcharacter/llpose.cpp b/linden/indra/llcharacter/llpose.cpp index a07cd58..1e637d7 100644 --- a/linden/indra/llcharacter/llpose.cpp +++ b/linden/indra/llcharacter/llpose.cpp @@ -2,6 +2,8 @@ * @file llpose.cpp * @brief Implementation of LLPose class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- diff --git a/linden/indra/llcharacter/llpose.h b/linden/indra/llcharacter/llpose.h index 4e1bb64..fe0a238 100644 --- a/linden/indra/llcharacter/llpose.h +++ b/linden/indra/llcharacter/llpose.h @@ -2,6 +2,8 @@ * @file llpose.h * @brief Implementation of LLPose class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPOSE_H diff --git a/linden/indra/llcharacter/llstatemachine.cpp b/linden/indra/llcharacter/llstatemachine.cpp index d7ecae4..b3432b2 100644 --- a/linden/indra/llcharacter/llstatemachine.cpp +++ b/linden/indra/llcharacter/llstatemachine.cpp @@ -2,6 +2,8 @@ * @file llstatemachine.cpp * @brief LLStateMachine implementation file. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcharacter/llstatemachine.h b/linden/indra/llcharacter/llstatemachine.h index 091662e..6983729 100644 --- a/linden/indra/llcharacter/llstatemachine.h +++ b/linden/indra/llcharacter/llstatemachine.h @@ -2,6 +2,8 @@ * @file llstatemachine.h * @brief LLStateMachine class header file. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSTATEMACHINE_H diff --git a/linden/indra/llcharacter/lltargetingmotion.cpp b/linden/indra/llcharacter/lltargetingmotion.cpp index 9e8b8df..d5fe654 100644 --- a/linden/indra/llcharacter/lltargetingmotion.cpp +++ b/linden/indra/llcharacter/lltargetingmotion.cpp @@ -2,6 +2,8 @@ * @file lltargetingmotion.cpp * @brief Implementation of LLTargetingMotion class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- diff --git a/linden/indra/llcharacter/lltargetingmotion.h b/linden/indra/llcharacter/lltargetingmotion.h index a6a6b03..9877467 100644 --- a/linden/indra/llcharacter/lltargetingmotion.h +++ b/linden/indra/llcharacter/lltargetingmotion.h @@ -2,6 +2,8 @@ * @file lltargetingmotion.h * @brief Implementation of LLTargetingMotion class. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTARGETINGMOTION_H diff --git a/linden/indra/llcharacter/llvisualparam.cpp b/linden/indra/llcharacter/llvisualparam.cpp index d1c08f9..065bf9f 100644 --- a/linden/indra/llcharacter/llvisualparam.cpp +++ b/linden/indra/llcharacter/llvisualparam.cpp @@ -2,6 +2,8 @@ * @file llvisualparam.cpp * @brief Implementation of LLPolyMesh class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- diff --git a/linden/indra/llcharacter/llvisualparam.h b/linden/indra/llcharacter/llvisualparam.h index ddd0469..43911f4 100644 --- a/linden/indra/llcharacter/llvisualparam.h +++ b/linden/indra/llcharacter/llvisualparam.h @@ -2,6 +2,8 @@ * @file llvisualparam.h * @brief Implementation of LLPolyMesh class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVisualParam_H @@ -116,9 +119,9 @@ public: const LLString& getMaxDisplayName() const { return mInfo->mMaxName; } const LLString& getMinDisplayName() const { return mInfo->mMinName; } - void setDisplayName(const char* s) { mInfo->mDisplayName = s; } - void setMaxDisplayName(const char* s) { mInfo->mMaxName = s; } - void setMinDisplayName(const char* s) { mInfo->mMinName = s; } + void setDisplayName(const LLString& s) { mInfo->mDisplayName = s; } + void setMaxDisplayName(const LLString& s) { mInfo->mMaxName = s; } + void setMinDisplayName(const LLString& s) { mInfo->mMinName = s; } EVisualParamGroup getGroup() { return mInfo->mGroup; } F32 getMinWeight() { return mInfo->mMinWeight; } diff --git a/linden/indra/llcommon/bitpack.h b/linden/indra/llcommon/bitpack.h index 89af101..1a382ff 100644 --- a/linden/indra/llcommon/bitpack.h +++ b/linden/indra/llcommon/bitpack.h @@ -2,6 +2,8 @@ * @file bitpack.h * @brief Convert data to packed bit stream * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_BITPACK_H diff --git a/linden/indra/llcommon/ctype_workaround.h b/linden/indra/llcommon/ctype_workaround.h index 20dd6c6..7c730d9 100644 --- a/linden/indra/llcommon/ctype_workaround.h +++ b/linden/indra/llcommon/ctype_workaround.h @@ -3,6 +3,8 @@ * @brief The workaround is to create some legacy symbols that point * to the correct symbols, which avoids link errors. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef _CTYPE_WORKAROUND_H_ @@ -38,7 +41,7 @@ * -- Leviathan 20060113 */ -#include +#include __const unsigned short int *__ctype_b; __const __int32_t *__ctype_tolower; diff --git a/linden/indra/llcommon/doublelinkedlist.h b/linden/indra/llcommon/doublelinkedlist.h index 81891b3..11cfb48 100644 --- a/linden/indra/llcommon/doublelinkedlist.h +++ b/linden/indra/llcommon/doublelinkedlist.h @@ -2,6 +2,8 @@ * @file doublelinkedlist.h * @brief Provides a standard doubly linked list for fun and profit. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_DOUBLELINKEDLIST_H diff --git a/linden/indra/llcommon/files.lst b/linden/indra/llcommon/files.lst index 0474cbb..f7bf5e3 100644 --- a/linden/indra/llcommon/files.lst +++ b/linden/indra/llcommon/files.lst @@ -1,5 +1,6 @@ llcommon/llapp.cpp llcommon/llapr.cpp +llcommon/llares.cpp llcommon/llassettype.cpp llcommon/llbase32.cpp llcommon/llbase64.cpp diff --git a/linden/indra/llcommon/imageids.h b/linden/indra/llcommon/imageids.h index 5c6ff08..cc7c70e 100644 --- a/linden/indra/llcommon/imageids.h +++ b/linden/indra/llcommon/imageids.h @@ -2,6 +2,8 @@ * @file imageids.h * @brief Temporary holder for image IDs * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_IMAGEIDS_H diff --git a/linden/indra/llcommon/indra_constants.h b/linden/indra/llcommon/indra_constants.h index bd591c5..b7d3578 100644 --- a/linden/indra/llcommon/indra_constants.h +++ b/linden/indra/llcommon/indra_constants.h @@ -2,6 +2,8 @@ * @file indra_constants.h * @brief some useful short term constants for Indra * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_INDRA_CONSTANTS_H diff --git a/linden/indra/llcommon/linden_common.h b/linden/indra/llcommon/linden_common.h index 24a346c..39ee014 100644 --- a/linden/indra/llcommon/linden_common.h +++ b/linden/indra/llcommon/linden_common.h @@ -2,6 +2,8 @@ * @file linden_common.h * @brief Includes common headers that are always safe to include * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LINDEN_COMMON_H @@ -31,34 +34,42 @@ #include "llpreprocessor.h" -#include -#include -#include -#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include // Work around stupid Microsoft STL warning #ifdef LL_WINDOWS #pragma warning (disable : 4702) // warning C4702: unreachable code #endif // LL_WINDOWS -#include -#include +#include +#include +#include #include #include -#include "llfile.h" +#ifdef LL_WINDOWS +#pragma warning (3 : 4702) // we like level 3, not 4 +#endif // LL_WINDOWS + +// Linden only libs in alpha-order other than stdtypes.h #include "stdtypes.h" #include "lldefs.h" #include "llerror.h" #include "llextendedstatus.h" +#include "llfasttimer.h" +#include "llfile.h" #include "llformat.h" #include "llstring.h" -#include "lltimer.h" -#include "llfasttimer.h" #include "llsys.h" - -#ifdef LL_WINDOWS -#pragma warning (3 : 4702) // we like level 3, not 4 -#endif // LL_WINDOWS +#include "lltimer.h" #endif diff --git a/linden/indra/llcommon/linked_lists.h b/linden/indra/llcommon/linked_lists.h index ab4a622..0162a07 100644 --- a/linden/indra/llcommon/linked_lists.h +++ b/linden/indra/llcommon/linked_lists.h @@ -2,6 +2,8 @@ * @file linked_lists.h * @brief LLLinkedList class header amd implementation file. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LINKED_LISTS_H diff --git a/linden/indra/llcommon/llagentconstants.h b/linden/indra/llcommon/llagentconstants.h index 0e0fdb0..2989d6d 100644 --- a/linden/indra/llcommon/llagentconstants.h +++ b/linden/indra/llcommon/llagentconstants.h @@ -3,6 +3,8 @@ * @author James Cook, Andrew Meadows, Richard Nelson * @brief Shared constants through the system for agents. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLAGENTCONSTANTS_H diff --git a/linden/indra/llcommon/llapp.cpp b/linden/indra/llcommon/llapp.cpp index 5edcb3c..b0751b8 100644 --- a/linden/indra/llcommon/llapp.cpp +++ b/linden/indra/llcommon/llapp.cpp @@ -2,6 +2,8 @@ * @file llapp.cpp * @brief Implementation of the LLApp class. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/llapp.h b/linden/indra/llcommon/llapp.h index 599bd48..d64af62 100644 --- a/linden/indra/llcommon/llapp.h +++ b/linden/indra/llcommon/llapp.h @@ -2,6 +2,8 @@ * @file llapp.h * @brief Declaration of the LLApp class. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLAPP_H diff --git a/linden/indra/llcommon/llapr.cpp b/linden/indra/llcommon/llapr.cpp index ee63497..be3a52d 100644 --- a/linden/indra/llcommon/llapr.cpp +++ b/linden/indra/llcommon/llapr.cpp @@ -4,6 +4,8 @@ * @date 2004-11-28 * @brief Helper functions for using the apache portable runtime library. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -44,7 +47,7 @@ void ll_init_apr() apr_pool_create(&gAPRPoolp, NULL); // Initialize the logging mutex - apr_thread_mutex_create(&gLogMutexp, APR_THREAD_MUTEX_DEFAULT, gAPRPoolp); + apr_thread_mutex_create(&gLogMutexp, APR_THREAD_MUTEX_UNNESTED, gAPRPoolp); } } diff --git a/linden/indra/llcommon/llapr.h b/linden/indra/llcommon/llapr.h index 6edfc18..b6c3638 100644 --- a/linden/indra/llcommon/llapr.h +++ b/linden/indra/llcommon/llapr.h @@ -4,6 +4,8 @@ * @date 2004-11-28 * @brief Helper functions for using the apache portable runtime library. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLAPR_H @@ -44,6 +47,7 @@ #include "apr-1/apr_atomic.h" #include "llstring.h" +extern apr_thread_mutex_t* gLogMutexp; /** * @brief initialize the common apr constructs -- apr itself, the diff --git a/linden/indra/llcommon/llares.cpp b/linden/indra/llcommon/llares.cpp new file mode 100644 index 0000000..3118830 --- /dev/null +++ b/linden/indra/llcommon/llares.cpp @@ -0,0 +1,776 @@ +/** + * @file llares.cpp + * @author Bryan O'Sullivan + * @date 2007-08-15 + * @brief Wrapper for asynchronous DNS lookups. + * + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. + * + * Second Life Viewer Source Code + * The source code in this file ("Source Code") is provided by Linden Lab + * to you under the terms of the GNU General Public License, version 2.0 + * ("GPL"), unless you have obtained a separate licensing agreement + * ("Other License"), formally executed by you and Linden Lab. Terms of + * the GPL can be found in doc/GPL-license.txt in this distribution, or + * online at http://secondlife.com/developers/opensource/gplv2 + * + * There are special exceptions to the terms and conditions of the GPL as + * it is applied to this Source Code. View the full text of the exception + * in the file doc/FLOSS-exception.txt in this software distribution, or + * online at http://secondlife.com/developers/opensource/flossexception + * + * By copying, modifying or distributing this software, you acknowledge + * that you have read and understood your obligations described above, + * and agree to abide by those obligations. + * + * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO + * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, + * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ + */ + +#ifdef LL_STANDALONE +# include +#else +# include +#endif + +#include "apr-1/apr_portable.h" +#include "apr-1/apr_network_io.h" +#include "apr-1/apr_poll.h" + +#include "linden_common.h" +#include "llapr.h" +#include "llares.h" + +#if defined(LL_WINDOWS) +# define ns_c_in 1 +# define NS_HFIXEDSZ 12 /* #/bytes of fixed data in header */ +# define NS_QFIXEDSZ 4 /* #/bytes of fixed data in query */ +# define NS_RRFIXEDSZ 10 /* #/bytes of fixed data in r record */ +#else +# include +#endif + +LLAres::HostResponder::~HostResponder() +{ +} + +void LLAres::HostResponder::hostResult(const hostent *ent) +{ + llinfos << "LLAres::HostResponder::hostResult not implemented" << llendl; +} + +void LLAres::HostResponder::hostError(int code) +{ + llinfos << "LLAres::HostResponder::hostError " << code << ": " + << LLAres::strerror(code) << llendl; +} + +LLAres::NameInfoResponder::~NameInfoResponder() +{ +} + +void LLAres::NameInfoResponder::nameInfoResult(const char *node, + const char *service) +{ + llinfos << "LLAres::NameInfoResponder::nameInfoResult not implemented" + << llendl; +} + +void LLAres::NameInfoResponder::nameInfoError(int code) +{ + llinfos << "LLAres::NameInfoResponder::nameInfoError " << code << ": " + << LLAres::strerror(code) << llendl; +} + +LLAres::QueryResponder::~QueryResponder() +{ +} + +void LLAres::QueryResponder::queryResult(const char *buf, size_t len) +{ + llinfos << "LLAres::QueryResponder::queryResult not implemented" + << llendl; +} + +void LLAres::QueryResponder::queryError(int code) +{ + llinfos << "LLAres::QueryResponder::queryError " << code << ": " + << LLAres::strerror(code) << llendl; +} + +LLAres::LLAres() +{ + ares_init(&chan_); +} + +LLAres::~LLAres() +{ + ares_destroy(chan_); +} + +void LLAres::cancel() +{ + ares_cancel(chan_); +} + +static void host_callback(void *arg, int status, struct hostent *ent) +{ + LLPointer *resp = + (LLPointer *) arg; + + if (status == ARES_SUCCESS) + { + (*resp)->hostResult(ent); + } else { + (*resp)->hostError(status); + } + + delete resp; +} + +void LLAres::getHostByName(const char *name, HostResponder *resp, + int family) +{ + ares_gethostbyname(chan_, name, family, host_callback, + new LLPointer(resp)); +} + +void LLAres::getSrvRecords(const std::string &name, SrvResponder *resp) +{ + search(name, RES_SRV, resp); +} + +void LLAres::rewriteURI(const std::string &uri, UriRewriteResponder *resp) +{ + llinfos << "Rewriting " << uri << llendl; + + resp->mUri = LLURI(uri); + search("_" + resp->mUri.scheme() + "._tcp." + resp->mUri.hostName(), + RES_SRV, resp); +} + +LLQueryResponder::LLQueryResponder() + : LLAres::QueryResponder(), + mResult(ARES_ENODATA) +{ +} + +int LLQueryResponder::parseRR(const char *buf, size_t len, const char *&pos, + LLPointer &r) +{ + std::string rrname; + size_t enclen; + int ret; + + // RR name. + + ret = LLAres::expandName(pos, buf, len, rrname, enclen); + if (ret != ARES_SUCCESS) + { + return ret; + } + + pos += enclen; + + if (pos + NS_RRFIXEDSZ > buf + len) + { + return ARES_EBADRESP; + } + + int rrtype = DNS_RR_TYPE(pos); + int rrclass = DNS_RR_CLASS(pos); + int rrttl = DNS_RR_TTL(pos); + int rrlen = DNS_RR_LEN(pos); + + if (rrclass != ns_c_in) + { + return ARES_EBADRESP; + } + + pos += NS_RRFIXEDSZ; + + if (pos + rrlen > buf + len) + { + return ARES_EBADRESP; + } + + switch (rrtype) + { + case RES_A: + r = new LLARecord(rrname, rrttl); + break; + case RES_NS: + r = new LLNsRecord(rrname, rrttl); + break; + case RES_CNAME: + r = new LLCnameRecord(rrname, rrttl); + break; + case RES_PTR: + r = new LLPtrRecord(rrname, rrttl); + break; + case RES_AAAA: + r = new LLAaaaRecord(rrname, rrttl); + break; + case RES_SRV: + r = new LLSrvRecord(rrname, rrttl); + break; + default: + llinfos << "LLQueryResponder::parseRR got unknown RR type " << rrtype + << llendl; + return ARES_EBADRESP; + } + + ret = r->parse(buf, len, pos, rrlen); + + if (ret == ARES_SUCCESS) + { + pos += rrlen; + } else { + r = NULL; + } + + return ret; +} + +int LLQueryResponder::parseSection(const char *buf, size_t len, + size_t count, const char *&pos, + dns_rrs_t &rrs) +{ + int ret = ARES_SUCCESS; + + for (size_t i = 0; i < count; i++) + { + LLPointer r; + ret = parseRR(buf, len, pos, r); + if (ret != ARES_SUCCESS) + { + break; + } + rrs.push_back(r); + } + + return ret; +} + +void LLQueryResponder::queryResult(const char *buf, size_t len) +{ + const char *pos = buf; + int qdcount = DNS_HEADER_QDCOUNT(pos); + int ancount = DNS_HEADER_ANCOUNT(pos); + int nscount = DNS_HEADER_NSCOUNT(pos); + int arcount = DNS_HEADER_ARCOUNT(pos); + int ret; + + if (qdcount == 0 || ancount + nscount + arcount == 0) + { + ret = ARES_ENODATA; + goto bail; + } + + pos += NS_HFIXEDSZ; + + for (int i = 0; i < qdcount; i++) + { + std::string ignore; + size_t enclen; + + ret = LLAres::expandName(pos, buf, len, i == 0 ? mQuery : ignore, + enclen); + if (ret != ARES_SUCCESS) + { + goto bail; + } + + pos += enclen; + + if (i == 0) + { + int t = DNS_QUESTION_TYPE(pos); + switch (t) + { + case RES_A: + case RES_NS: + case RES_CNAME: + case RES_PTR: + case RES_AAAA: + case RES_SRV: + mType = (LLResType) t; + break; + default: + llinfos << "Cannot grok query type " << t << llendl; + ret = ARES_EBADQUERY; + goto bail; + } + } + + pos += NS_QFIXEDSZ; + if (pos > buf + len) + { + ret = ARES_EBADRESP; + goto bail; + } + } + + ret = parseSection(buf, len, ancount, pos, mAnswers); + if (ret != ARES_SUCCESS) + { + goto bail; + } + + ret = parseSection(buf, len, nscount, pos, mAuthorities); + if (ret != ARES_SUCCESS) + { + goto bail; + } + + ret = parseSection(buf, len, arcount, pos, mAdditional); + +bail: + mResult = ret; + if (mResult == ARES_SUCCESS) + { + queryResult(); + } else { + queryError(mResult); + } +} + +void LLQueryResponder::queryResult() +{ + llinfos << "LLQueryResponder::queryResult not implemented" << llendl; +} + +void LLAres::SrvResponder::queryResult() +{ + if (mType == RES_SRV) + { + srvResult(mAnswers); + } else { + srvError(ARES_EBADRESP); + } +} + +void LLAres::SrvResponder::queryError(int code) +{ + srvError(code); +} + +void LLAres::SrvResponder::srvResult(const dns_rrs_t &ents) +{ + llinfos << "LLAres::SrvResponder::srvResult not implemented" << llendl; + + for (size_t i = 0; i < ents.size(); i++) + { + const LLSrvRecord *s = (const LLSrvRecord *) ents[i].get(); + + llinfos << "[" << i << "] " << s->host() << ":" << s->port() + << " priority " << s->priority() + << " weight " << s->weight() + << llendl; + } +} + +void LLAres::SrvResponder::srvError(int code) +{ + llinfos << "LLAres::SrvResponder::srvError " << code << ": " + << LLAres::strerror(code) << llendl; +} + +static void nameinfo_callback(void *arg, int status, char *node, char *service) +{ + LLPointer *resp = + (LLPointer *) arg; + + if (status == ARES_SUCCESS) + { + (*resp)->nameInfoResult(node, service); + } else { + (*resp)->nameInfoError(status); + } + + delete resp; +} + +void LLAres::getNameInfo(const struct sockaddr &sa, socklen_t salen, int flags, + NameInfoResponder *resp) +{ + ares_getnameinfo(chan_, &sa, salen, flags, nameinfo_callback, + new LLPointer(resp)); +} + +static void search_callback(void *arg, int status, unsigned char *abuf, + int alen) +{ + LLPointer *resp = + (LLPointer *) arg; + + if (status == ARES_SUCCESS) + { + (*resp)->queryResult((const char *) abuf, alen); + } else { + (*resp)->queryError(status); + } + + delete resp; +} + +void LLAres::search(const std::string &query, LLResType type, + QueryResponder *resp) +{ + ares_search(chan_, query.c_str(), ns_c_in, type, search_callback, + new LLPointer(resp)); +} + +bool LLAres::process(U64 timeout) +{ + if (!gAPRPoolp) + { + ll_init_apr(); + } + + int socks[ARES_GETSOCK_MAXNUM]; + apr_pollfd_t aprFds[ARES_GETSOCK_MAXNUM]; + apr_int32_t nsds = 0; + apr_status_t status; + apr_pool_t *pool; + int nactive = 0; + int bitmask; + + bitmask = ares_getsock(chan_, socks, ARES_GETSOCK_MAXNUM); + + if (bitmask == 0) + { + goto bail; + } + + status = apr_pool_create(&pool, gAPRPoolp); + ll_apr_assert_status(status); + + for (int i = 0; i < ARES_GETSOCK_MAXNUM; i++) + { + if (ARES_GETSOCK_READABLE(bitmask, i)) + { + aprFds[nactive].reqevents = APR_POLLIN | APR_POLLERR; + } + else if (ARES_GETSOCK_WRITABLE(bitmask, i)) + { + aprFds[nactive].reqevents = APR_POLLOUT | APR_POLLERR; + } else { + continue; + } + + apr_socket_t *aprSock = NULL; + + status = apr_os_sock_put(&aprSock, (apr_os_sock_t *) &socks[i], pool); + if (status != APR_SUCCESS) + { + ll_apr_warn_status(status); + goto bail_pool; + } + + aprFds[nactive].desc.s = aprSock; + aprFds[nactive].desc_type = APR_POLL_SOCKET; + aprFds[nactive].p = pool; + aprFds[nactive].rtnevents = 0; + aprFds[nactive].client_data = &socks[i]; + + nactive++; + } + + if (nactive > 0) + { + status = apr_poll(aprFds, nactive, &nsds, timeout); + + if (status != APR_SUCCESS && status != APR_TIMEUP) + { + ll_apr_warn_status(status); + } + + for (int i = 0; i < nactive; i++) + { + int evts = aprFds[i].rtnevents; + int ifd = (evts & (APR_POLLIN | APR_POLLERR)) + ? *((int *) aprFds[i].client_data) : ARES_SOCKET_BAD; + int ofd = (evts & (APR_POLLOUT | APR_POLLERR)) + ? *((int *) aprFds[i].client_data) : ARES_SOCKET_BAD; + + ares_process_fd(chan_, ifd, ofd); + } + } + +bail_pool: + apr_pool_destroy(pool); + +bail: + return nsds > 0; +} + +bool LLAres::processAll() +{ + bool anyProcessed = false, ret; + + do { + timeval tv; + + ret = ares_timeout(chan_, NULL, &tv) != NULL; + + if (ret) + { + ret = process(tv.tv_sec * 1000000LL + tv.tv_usec); + anyProcessed |= ret; + } + } while (ret); + + return anyProcessed; +} + +int LLAres::expandName(const char *encoded, const char *abuf, size_t alen, + std::string &s, size_t &enclen) +{ + char *t; + int ret; + long e; + + ret = ares_expand_name((const unsigned char *) encoded, + (const unsigned char *) abuf, alen, &t, &e); + if (ret == ARES_SUCCESS) + { + s.assign(t); + enclen = e; + ares_free_string(t); + } + return ret; +} + +const char *LLAres::strerror(int code) +{ + return ares_strerror(code); +} + +LLAres *gAres; + +LLAres *ll_init_ares() +{ + if (gAres == NULL) + { + gAres = new LLAres(); + } + return gAres; +} + +LLDnsRecord::LLDnsRecord(LLResType type, const std::string &name, + unsigned ttl) + : LLRefCount(), + mType(type), + mName(name), + mTTL(ttl) +{ +} + +LLHostRecord::LLHostRecord(LLResType type, const std::string &name, + unsigned ttl) + : LLDnsRecord(type, name, ttl) +{ +} + +int LLHostRecord::parse(const char *buf, size_t len, const char *pos, + size_t rrlen) +{ + int ret; + + ret = LLAres::expandName(pos, buf, len, mHost); + if (ret != ARES_SUCCESS) + { + goto bail; + } + + ret = ARES_SUCCESS; + +bail: + return ret; +} + +LLCnameRecord::LLCnameRecord(const std::string &name, unsigned ttl) + : LLHostRecord(RES_CNAME, name, ttl) +{ +} + +LLPtrRecord::LLPtrRecord(const std::string &name, unsigned ttl) + : LLHostRecord(RES_PTR, name, ttl) +{ +} + +LLAddrRecord::LLAddrRecord(LLResType type, const std::string &name, + unsigned ttl) + : LLDnsRecord(type, name, ttl) +{ +} + +LLARecord::LLARecord(const std::string &name, unsigned ttl) + : LLAddrRecord(RES_A, name, ttl) +{ +} + +int LLARecord::parse(const char *buf, size_t len, const char *pos, + size_t rrlen) +{ + int ret; + + if (rrlen != sizeof(mSA.sin.sin_addr.s_addr)) + { + ret = ARES_EBADRESP; + goto bail; + } + + memset(&mSA, 0, sizeof(mSA)); + memcpy(&mSA.sin.sin_addr.s_addr, pos, rrlen); + mSA.sin.sin_family = AF_INET6; + mSize = sizeof(mSA.sin); + + ret = ARES_SUCCESS; + +bail: + return ret; +} + +LLAaaaRecord::LLAaaaRecord(const std::string &name, unsigned ttl) + : LLAddrRecord(RES_AAAA, name, ttl) +{ +} + +int LLAaaaRecord::parse(const char *buf, size_t len, const char *pos, + size_t rrlen) +{ + int ret; + + if (rrlen != sizeof(mSA.sin6.sin6_addr)) + { + ret = ARES_EBADRESP; + goto bail; + } + + memset(&mSA, 0, sizeof(mSA)); + memcpy(&mSA.sin6.sin6_addr.s6_addr, pos, rrlen); + mSA.sin6.sin6_family = AF_INET6; + mSize = sizeof(mSA.sin6); + + ret = ARES_SUCCESS; + +bail: + return ret; +} + +LLSrvRecord::LLSrvRecord(const std::string &name, unsigned ttl) + : LLHostRecord(RES_SRV, name, ttl) +{ +} + +int LLSrvRecord::parse(const char *buf, size_t len, const char *pos, + size_t rrlen) +{ + int ret; + + if (rrlen < 6) + { + ret = ARES_EBADRESP; + goto bail; + } + + memcpy(&mPriority, pos, 2); + memcpy(&mWeight, pos + 2, 2); + memcpy(&mPort, pos + 4, 2); + + mPriority = ntohs(mPriority); + mWeight = ntohs(mWeight); + mPort = ntohs(mPort); + + ret = LLHostRecord::parse(buf, len, pos + 6, rrlen - 6); + +bail: + return ret; +} + +LLNsRecord::LLNsRecord(const std::string &name, unsigned ttl) + : LLHostRecord(RES_NS, name, ttl) +{ +} + +void LLAres::UriRewriteResponder::queryError(int code) +{ + std::vector uris; + uris.push_back(mUri.asString()); + rewriteResult(uris); +} + +void LLAres::UriRewriteResponder::queryResult() +{ + std::vector uris; + + if (mType != RES_SRV) + { + goto bail; + } + + for (size_t i = 0; i < mAnswers.size(); i++) + { + const LLSrvRecord *r = (const LLSrvRecord *) mAnswers[i].get(); + + if (r->type() == RES_SRV) + { + // Check the domain in the response to ensure that it's + // the same as the domain in the request, so that bad guys + // can't forge responses that point to their own login + // servers with their own certificates. + + // Hard-coding the domain to check here is a bit of a + // hack. Hoist it to an outer caller if anyone ever needs + // this functionality on other domains. + + static const std::string domain(".lindenlab.com"); + const std::string &host = r->host(); + + std::string::size_type s = host.find(domain) + domain.length(); + + if (s != host.length() && s != host.length() - 1) + { + continue; + } + + LLURI uri(mUri.scheme(), + mUri.userName(), + mUri.password(), + r->host(), + mUri.defaultPort() ? r->port() : mUri.hostPort(), + mUri.escapedPath(), + mUri.escapedQuery()); + uris.push_back(uri.asString()); + } + } + + if (!uris.empty()) + { + goto done; + } + +bail: + uris.push_back(mUri.asString()); + +done: + rewriteResult(uris); +} + +void LLAres::UriRewriteResponder::rewriteResult( + const std::vector &uris) +{ + llinfos << "LLAres::UriRewriteResponder::rewriteResult not implemented" + << llendl; + + for (size_t i = 0; i < uris.size(); i++) + { + llinfos << "[" << i << "] " << uris[i] << llendl; + } +} diff --git a/linden/indra/llcommon/llares.h b/linden/indra/llcommon/llares.h new file mode 100644 index 0000000..63bb3e3 --- /dev/null +++ b/linden/indra/llcommon/llares.h @@ -0,0 +1,572 @@ +/** + * @file llares.h + * @author Bryan O'Sullivan + * @date 2007-08-15 + * @brief Wrapper for asynchronous DNS lookups. + * + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. + * + * Second Life Viewer Source Code + * The source code in this file ("Source Code") is provided by Linden Lab + * to you under the terms of the GNU General Public License, version 2.0 + * ("GPL"), unless you have obtained a separate licensing agreement + * ("Other License"), formally executed by you and Linden Lab. Terms of + * the GPL can be found in doc/GPL-license.txt in this distribution, or + * online at http://secondlife.com/developers/opensource/gplv2 + * + * There are special exceptions to the terms and conditions of the GPL as + * it is applied to this Source Code. View the full text of the exception + * in the file doc/FLOSS-exception.txt in this software distribution, or + * online at http://secondlife.com/developers/opensource/flossexception + * + * By copying, modifying or distributing this software, you acknowledge + * that you have read and understood your obligations described above, + * and agree to abide by those obligations. + * + * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO + * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, + * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ + */ + +#ifndef LL_LLARES_H +#define LL_LLARES_H + +#ifdef LL_WINDOWS +# include +#endif + +#ifdef LL_STANDALONE +# include +#else +# include +#endif + +#include "llmemory.h" +#include "lluri.h" + +class LLQueryResponder; + +/** + * @brief Supported DNS RR types. + */ +enum LLResType +{ + RES_INVALID = 0, /**< Cookie. */ + RES_A = 1, /**< "A" record. IPv4 address. */ + RES_NS = 2, /**< "NS" record. Authoritative server. */ + RES_CNAME = 5, /**< "CNAME" record. Canonical name. */ + RES_PTR = 12, /**< "PTR" record. Domain name pointer. */ + RES_AAAA = 28, /**< "AAAA" record. IPv6 Address. */ + RES_SRV = 33, /**< "SRV" record. Server Selection. */ + RES_MAX = 65536 /**< Sentinel; RR types are 16 bits wide. */ +}; + +/** + * @class LLDnsRecord + * @brief Base class for all DNS RR types. + */ +class LLDnsRecord : public LLRefCount +{ +protected: + friend class LLQueryResponder; + + LLResType mType; + std::string mName; + unsigned mTTL; + + virtual int parse(const char *buf, size_t len, const char *pos, + size_t rrlen) = 0; + + LLDnsRecord(LLResType type, const std::string &name, unsigned ttl); + +public: + /** + * @brief Record name. + */ + const std::string &name() const { return mName; } + + /** + * @brief Time-to-live value, in seconds. + */ + unsigned ttl() const { return mTTL; } + + /** + * @brief RR type. + */ + LLResType type() const { return mType; } +}; + +/** + * @class LLAddrRecord + * @brief Base class for address-related RRs. + */ +class LLAddrRecord : public LLDnsRecord +{ +protected: + friend class LLQueryResponder; + + LLAddrRecord(LLResType type, const std::string &name, unsigned ttl); + + union + { + sockaddr sa; + sockaddr_in sin; + sockaddr_in6 sin6; + } mSA; + + socklen_t mSize; + +public: + /** + * @brief Generic socket address. + */ + const sockaddr &addr() const { return mSA.sa; } + + /** + * @brief Size of the socket structure. + */ + socklen_t size() const { return mSize; } +}; + +/** + * @class LLARecord + * @brief A RR, for IPv4 addresses. + */ +class LLARecord : public LLAddrRecord +{ +protected: + friend class LLQueryResponder; + + LLARecord(const std::string &name, unsigned ttl); + + int parse(const char *buf, size_t len, const char *pos, size_t rrlen); + +public: + /** + * @brief Socket address. + */ + const sockaddr_in &addr_in() const { return mSA.sin; } +}; + +/** + * @class LLAaaaRecord + * @brief AAAA RR, for IPv6 addresses. + */ +class LLAaaaRecord : public LLAddrRecord +{ +protected: + friend class LLQueryResponder; + + LLAaaaRecord(const std::string &name, unsigned ttl); + + int parse(const char *buf, size_t len, const char *pos, size_t rrlen); + +public: + /** + * @brief Socket address. + */ + const sockaddr_in6 &addr_in6() const { return mSA.sin6; } +}; + +/** + * @class LLHostRecord + * @brief Base class for host-related RRs. + */ +class LLHostRecord : public LLDnsRecord +{ +protected: + LLHostRecord(LLResType type, const std::string &name, unsigned ttl); + + int parse(const char *buf, size_t len, const char *pos, size_t rrlen); + + std::string mHost; + +public: + /** + * @brief Host name. + */ + const std::string &host() const { return mHost; } +}; + +/** + * @class LLCnameRecord + * @brief CNAME RR. + */ +class LLCnameRecord : public LLHostRecord +{ +protected: + friend class LLQueryResponder; + + LLCnameRecord(const std::string &name, unsigned ttl); +}; + +/** + * @class LLPtrRecord + * @brief PTR RR. + */ +class LLPtrRecord : public LLHostRecord +{ +protected: + friend class LLQueryResponder; + + LLPtrRecord(const std::string &name, unsigned ttl); +}; + +/** + * @class LLSrvRecord + * @brief SRV RR. + */ +class LLSrvRecord : public LLHostRecord +{ +protected: + U16 mPriority; + U16 mWeight; + U16 mPort; + + int parse(const char *buf, size_t len, const char *pos, size_t rrlen); + +public: + LLSrvRecord(const std::string &name, unsigned ttl); + + /** + * @brief Service priority. + */ + U16 priority() const { return mPriority; } + + /** + * @brief Service weight. + */ + U16 weight() const { return mWeight; } + + /** + * @brief Port number of service. + */ + U16 port() const { return mPort; } + + /** + * @brief Functor for sorting SRV records by priority. + */ + struct ComparePriorityLowest + { + bool operator()(const LLSrvRecord& lhs, const LLSrvRecord& rhs) + { + return lhs.mPriority < rhs.mPriority; + } + }; +}; + +/** + * @class LLNsRecord + * @brief NS RR. + */ +class LLNsRecord : public LLHostRecord +{ +public: + LLNsRecord(const std::string &name, unsigned ttl); +}; + +class LLQueryResponder; + +/** + * @class LLAres + * @brief Asynchronous address resolver. + */ +class LLAres +{ +public: + /** + * @class HostResponder + * @brief Base class for responding to hostname lookups. + * @see LLAres::getHostByName + */ + class HostResponder : public LLRefCount + { + public: + virtual ~HostResponder(); + + virtual void hostResult(const hostent *ent); + virtual void hostError(int code); + }; + + /** + * @class NameInfoResponder + * @brief Base class for responding to address lookups. + * @see LLAres::getNameInfo + */ + class NameInfoResponder : public LLRefCount + { + public: + virtual ~NameInfoResponder(); + + virtual void nameInfoResult(const char *node, const char *service); + virtual void nameInfoError(int code); + }; + + /** + * @class QueryResponder + * @brief Base class for responding to custom searches. + * @see LLAres::search + */ + class QueryResponder : public LLRefCount + { + public: + virtual ~QueryResponder(); + + virtual void queryResult(const char *buf, size_t len); + virtual void queryError(int code); + }; + + class SrvResponder; + class UriRewriteResponder; + + LLAres(); + + ~LLAres(); + + /** + * Cancel all outstanding requests. The error methods of the + * corresponding responders will be called, with ARES_ETIMEOUT. + */ + void cancel(); + + /** + * Look up the address of a host. + * + * @param name name of host to look up + * @param resp responder to call with result + * @param family AF_INET for IPv4 addresses, AF_INET6 for IPv6 + */ + void getHostByName(const std::string &name, HostResponder *resp, + int family = AF_INET) { + getHostByName(name.c_str(), resp, family); + } + + /** + * Look up the address of a host. + * + * @param name name of host to look up + * @param resp responder to call with result + * @param family AF_INET for IPv4 addresses, AF_INET6 for IPv6 + */ + void getHostByName(const char *name, HostResponder *resp, + int family = PF_INET); + + /** + * Look up the name associated with a socket address. + * + * @param sa socket address to look up + * @param salen size of socket address + * @param flags flags to use + * @param resp responder to call with result + */ + void getNameInfo(const struct sockaddr &sa, socklen_t salen, int flags, + NameInfoResponder *resp); + + /** + * Look up SRV (service location) records for a service name. + * + * @param name service name (e.g. "_https._tcp.login.agni.lindenlab.com") + * @param resp responder to call with result + */ + void getSrvRecords(const std::string &name, SrvResponder *resp); + + /** + * Rewrite a URI, using SRV (service location) records for its + * protocol if available. If no SRV records are published, the + * existing URI is handed to the responder. + * + * @param uri URI to rewrite + * @param resp responder to call with result + */ + void rewriteURI(const std::string &uri, + UriRewriteResponder *resp); + + /** + * Start a custom search. + * + * @param query query to make + * @param type type of query to perform + * @param resp responder to call with result + */ + void search(const std::string &query, LLResType type, + QueryResponder *resp); + + /** + * Process any outstanding queries. This method takes an optional + * timeout parameter (specified in microseconds). If provided, it + * will block the calling thread for that length of time to await + * possible responses. A timeout of zero will return immediately + * if there are no responses or timeouts to process. + * + * @param timeoutUsecs number of microseconds to block before timing out + * @return whether any responses were processed + */ + bool process(U64 timeoutUsecs = 0); + + /** + * Process all outstanding queries, blocking the calling thread + * until all have either been responded to or timed out. + * + * @return whether any responses were processed + */ + bool processAll(); + + /** + * Expand a DNS-encoded compressed string into a normal string. + * + * @param encoded the encoded name (null-terminated) + * @param abuf the response buffer in which the string is embedded + * @param alen the length of the response buffer + * @param s the string into which to place the result + * @return ARES_SUCCESS on success, otherwise an error indicator + */ + static int expandName(const char *encoded, const char *abuf, size_t alen, + std::string &s) { + size_t ignore; + return expandName(encoded, abuf, alen, s, ignore); + } + + static int expandName(const char *encoded, const char *abuf, size_t alen, + std::string &s, size_t &enclen); + + /** + * Return a string describing an error code. + */ + static const char *strerror(int code); + +protected: + ares_channel chan_; + +}; + +/** + * An ordered collection of DNS resource records. + */ +typedef std::vector > dns_rrs_t; + +/** + * @class LLQueryResponder + * @brief Base class for friendly handling of DNS query responses. + * + * This class parses a DNS response and represents it in a friendly + * manner. + * + * @see LLDnsRecord + * @see LLARecord + * @see LLNsRecord + * @see LLCnameRecord + * @see LLPtrRecord + * @see LLAaaaRecord + * @see LLSrvRecord + */ +class LLQueryResponder : public LLAres::QueryResponder +{ +protected: + int mResult; + std::string mQuery; + LLResType mType; + + dns_rrs_t mAnswers; + dns_rrs_t mAuthorities; + dns_rrs_t mAdditional; + + /** + * Parse a single RR. + */ + int parseRR(const char *buf, size_t len, const char *&pos, + LLPointer &r); + /** + * Parse one section of a response. + */ + int parseSection(const char *buf, size_t len, + size_t count, const char *& pos, dns_rrs_t &rrs); + + void queryResult(const char *buf, size_t len); + virtual void queryResult(); + +public: + LLQueryResponder(); + + /** + * Indicate whether the response could be parsed successfully. + */ + bool valid() const { return mResult == ARES_SUCCESS; } + + /** + * The more detailed result of parsing the response. + */ + int result() const { return mResult; } + + /** + * Return the query embedded in the response. + */ + const std::string &query() const { return mQuery; } + + /** + * Return the contents of the "answers" section of the response. + */ + const dns_rrs_t &answers() const { return mAnswers; } + + /** + * Return the contents of the "authorities" section of the + * response. + */ + const dns_rrs_t &authorities() const { return mAuthorities; } + + /** + * Return the contents of the "additional records" section of the + * response. + */ + const dns_rrs_t &additional() const { return mAdditional; } +}; + +/** + * @class LLAres::SrvResponder + * @brief Class for handling SRV query responses. + */ +class LLAres::SrvResponder : public LLQueryResponder +{ +public: + friend void LLAres::getSrvRecords(const std::string &name, + SrvResponder *resp); + void queryResult(); + void queryError(int code); + + virtual void srvResult(const dns_rrs_t &ents); + virtual void srvError(int code); +}; + +/** + * @class LLAres::UriRewriteResponder + * @brief Class for handling URI rewrites based on SRV records. + */ +class LLAres::UriRewriteResponder : public LLQueryResponder +{ +protected: + LLURI mUri; + +public: + friend void LLAres::rewriteURI(const std::string &uri, + UriRewriteResponder *resp); + void queryResult(); + void queryError(int code); + + virtual void rewriteResult(const std::vector &uris); +}; + +/** + * Singleton responder. + */ +extern LLAres *gAres; + +/** + * Set up the singleton responder. It's safe to call this more than + * once from within a single thread, but this function is not + * thread safe. + */ +extern LLAres *ll_init_ares(); + +#endif // LL_LLARES_H diff --git a/linden/indra/llcommon/llassettype.cpp b/linden/indra/llcommon/llassettype.cpp index 0bbef8c..06504b5 100644 --- a/linden/indra/llcommon/llassettype.cpp +++ b/linden/indra/llcommon/llassettype.cpp @@ -2,6 +2,8 @@ * @file llassettype.cpp * @brief Implementatino of LLAssetType functionality. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,14 +26,13 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" #include "llassettype.h" -#include - #include "llstring.h" #include "lltimer.h" diff --git a/linden/indra/llcommon/llassettype.h b/linden/indra/llcommon/llassettype.h index 5fe6b16..f71e0b9 100644 --- a/linden/indra/llcommon/llassettype.h +++ b/linden/indra/llcommon/llassettype.h @@ -2,6 +2,8 @@ * @file llassettype.h * @brief Declaration of LLAssetType. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLASSETTYPE diff --git a/linden/indra/llcommon/llassoclist.h b/linden/indra/llcommon/llassoclist.h index 417e347..974bc1e 100644 --- a/linden/indra/llcommon/llassoclist.h +++ b/linden/indra/llcommon/llassoclist.h @@ -2,6 +2,8 @@ * @file llassoclist.h * @brief LLAssocList class header file * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLASSOCLIST_H diff --git a/linden/indra/llcommon/llavatarconstants.h b/linden/indra/llcommon/llavatarconstants.h index ab49368..c62cae2 100644 --- a/linden/indra/llcommon/llavatarconstants.h +++ b/linden/indra/llcommon/llavatarconstants.h @@ -2,6 +2,8 @@ * @file llavatarconstants.h * @brief some useful short term constants for Indra * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_AVATAR_CONSTANTS_H diff --git a/linden/indra/llcommon/llbase32.cpp b/linden/indra/llcommon/llbase32.cpp index 27f7284..50f789e 100644 --- a/linden/indra/llcommon/llbase32.cpp +++ b/linden/indra/llcommon/llbase32.cpp @@ -7,7 +7,9 @@ * http://ghostwhitecrab.com/bitter/ * * Some parts of this file are: - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -29,6 +31,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /** diff --git a/linden/indra/llcommon/llbase32.h b/linden/indra/llcommon/llbase32.h index 198c5c6..5254d0a 100644 --- a/linden/indra/llcommon/llbase32.h +++ b/linden/indra/llcommon/llbase32.h @@ -3,7 +3,9 @@ * @brief base32 encoding that returns a std::string * @author James Cook * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLBASE32_H diff --git a/linden/indra/llcommon/llbase64.cpp b/linden/indra/llcommon/llbase64.cpp index 18aefea..207b367 100644 --- a/linden/indra/llcommon/llbase64.cpp +++ b/linden/indra/llcommon/llbase64.cpp @@ -3,7 +3,9 @@ * @brief Wrapper for apr base64 encoding that returns a std::string * @author James Cook * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/llbase64.h b/linden/indra/llcommon/llbase64.h index 995ac04..c3d1a11 100644 --- a/linden/indra/llcommon/llbase64.h +++ b/linden/indra/llcommon/llbase64.h @@ -3,7 +3,9 @@ * @brief Wrapper for apr base64 encoding that returns a std::string * @author James Cook * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLBASE64_H diff --git a/linden/indra/llcommon/llboost.h b/linden/indra/llcommon/llboost.h index 45d5eb2..14cc97c 100644 --- a/linden/indra/llcommon/llboost.h +++ b/linden/indra/llcommon/llboost.h @@ -2,6 +2,8 @@ * @file llboost.h * @brief helper object & functions for use with boost * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLBOOST_H diff --git a/linden/indra/llcommon/llchat.h b/linden/indra/llcommon/llchat.h index 7339e9a..0ae1638 100644 --- a/linden/indra/llcommon/llchat.h +++ b/linden/indra/llcommon/llchat.h @@ -3,6 +3,8 @@ * @author James Cook * @brief Chat constants and data structures. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCHAT_H diff --git a/linden/indra/llcommon/llclickaction.h b/linden/indra/llcommon/llclickaction.h index e45ad90..be343c6 100644 --- a/linden/indra/llcommon/llclickaction.h +++ b/linden/indra/llcommon/llclickaction.h @@ -3,6 +3,8 @@ * @author James Cook * @brief Constants for single-click actions on objects * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCLICKACTION_H diff --git a/linden/indra/llcommon/llcommon.cpp b/linden/indra/llcommon/llcommon.cpp index 993da7d..0069d03 100644 --- a/linden/indra/llcommon/llcommon.cpp +++ b/linden/indra/llcommon/llcommon.cpp @@ -1,6 +1,8 @@ /** * @file llcommon.cpp * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/llcommon.h b/linden/indra/llcommon/llcommon.h index 443870e..3f48763 100644 --- a/linden/indra/llcommon/llcommon.h +++ b/linden/indra/llcommon/llcommon.h @@ -1,6 +1,8 @@ /** * @file llcommon.h * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_COMMON_H diff --git a/linden/indra/llcommon/llcommon.vcproj b/linden/indra/llcommon/llcommon.vcproj index 70006e0..80704af 100644 --- a/linden/indra/llcommon/llcommon.vcproj +++ b/linden/indra/llcommon/llcommon.vcproj @@ -161,6 +161,9 @@ RelativePath=".\llapr.cpp"> + + + + @@ -447,6 +451,10 @@ > + + diff --git a/linden/indra/llcommon/llcriticaldamp.cpp b/linden/indra/llcommon/llcriticaldamp.cpp index f574550..9522573 100644 --- a/linden/indra/llcommon/llcriticaldamp.cpp +++ b/linden/indra/llcommon/llcriticaldamp.cpp @@ -2,6 +2,8 @@ * @file llcriticaldamp.cpp * @brief Implementation of the critical damping functionality. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,10 +26,10 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" -#include #include "llcriticaldamp.h" diff --git a/linden/indra/llcommon/llcriticaldamp.h b/linden/indra/llcommon/llcriticaldamp.h index 6a35e5e..e0b3df9 100644 --- a/linden/indra/llcommon/llcriticaldamp.h +++ b/linden/indra/llcommon/llcriticaldamp.h @@ -3,6 +3,8 @@ * @brief A lightweight class that calculates critical damping constants once * per frame. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCRITICALDAMP_H diff --git a/linden/indra/llcommon/lldarray.h b/linden/indra/llcommon/lldarray.h index 7942e77..3b46706 100644 --- a/linden/indra/llcommon/lldarray.h +++ b/linden/indra/llcommon/lldarray.h @@ -2,6 +2,8 @@ * @file lldarray.h * @brief Wrapped std::vector for backward compatibility. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDARRAY_H diff --git a/linden/indra/llcommon/lldarrayptr.h b/linden/indra/llcommon/lldarrayptr.h index 308101c..d04bffe 100644 --- a/linden/indra/llcommon/lldarrayptr.h +++ b/linden/indra/llcommon/lldarrayptr.h @@ -2,6 +2,8 @@ * @file lldarrayptr.h * @brief Wrapped std::vector for backward compatibility. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDARRAYPTR_H #define LL_LLDARRAYPTR_H diff --git a/linden/indra/llcommon/lldate.cpp b/linden/indra/llcommon/lldate.cpp index 47e5370..37b912d 100644 --- a/linden/indra/llcommon/lldate.cpp +++ b/linden/indra/llcommon/lldate.cpp @@ -4,6 +4,8 @@ * @date 2006-02-05 * @brief Implementation of the date class * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -61,6 +64,8 @@ LLDate::LLDate(const std::string& iso8601_date) { if(!fromString(iso8601_date)) { + llwarns << "date " << iso8601_date << " failed to parse; " + << "ZEROING IT OUT" << llendl; mSecondsSinceEpoch = DATE_EPOCH; } } @@ -212,7 +217,7 @@ bool LLDate::fromStream(std::istream& s) s >> fractional; seconds_since_epoch += fractional; } - s.get(); // skip the Z + c = s.get(); // skip the Z if (c != 'Z') { return false; } mSecondsSinceEpoch = seconds_since_epoch; diff --git a/linden/indra/llcommon/lldate.h b/linden/indra/llcommon/lldate.h index 5d90a54..7bff18d 100644 --- a/linden/indra/llcommon/lldate.h +++ b/linden/indra/llcommon/lldate.h @@ -4,6 +4,8 @@ * @date 2006-02-05 * @brief Declaration of a simple date class. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDATE_H diff --git a/linden/indra/llcommon/lldefs.h b/linden/indra/llcommon/lldefs.h index 25f4e73..cd8c79a 100644 --- a/linden/indra/llcommon/lldefs.h +++ b/linden/indra/llcommon/lldefs.h @@ -2,6 +2,8 @@ * @file lldefs.h * @brief Various generic constant definitions. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDEFS_H diff --git a/linden/indra/llcommon/lldepthstack.h b/linden/indra/llcommon/lldepthstack.h index f3ea709..dbde295 100644 --- a/linden/indra/llcommon/lldepthstack.h +++ b/linden/indra/llcommon/lldepthstack.h @@ -2,6 +2,8 @@ * @file lldepthstack.h * @brief Declaration of the LLDepthStack class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDEPTHSTACK_H diff --git a/linden/indra/llcommon/lldlinked.h b/linden/indra/llcommon/lldlinked.h index 0e39f69..d37d11e 100644 --- a/linden/indra/llcommon/lldlinked.h +++ b/linden/indra/llcommon/lldlinked.h @@ -2,6 +2,8 @@ * @file lldlinked.h * @brief Declaration of the LLDLinked class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,12 +26,11 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDLINKED_H #define LL_LLDLINKED_H -#include - template class LLDLinked { LLDLinked* mNextp; diff --git a/linden/indra/llcommon/lldqueueptr.h b/linden/indra/llcommon/lldqueueptr.h index aca73d9..06eee34 100644 --- a/linden/indra/llcommon/lldqueueptr.h +++ b/linden/indra/llcommon/lldqueueptr.h @@ -2,6 +2,8 @@ * @file lldqueueptr.h * @brief LLDynamicQueuePtr declaration * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDQUEUEPTR_H #define LL_LLDQUEUEPTR_H diff --git a/linden/indra/llcommon/llendianswizzle.h b/linden/indra/llcommon/llendianswizzle.h index d06af70..d2a9e40 100644 --- a/linden/indra/llcommon/llendianswizzle.h +++ b/linden/indra/llcommon/llendianswizzle.h @@ -2,6 +2,8 @@ * @file llendianswizzle.h * @brief Functions for in-place bit swizzling * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLENDIANSWIZZLE_H diff --git a/linden/indra/llcommon/llenum.h b/linden/indra/llcommon/llenum.h index 3e75a22..53db01d 100644 --- a/linden/indra/llcommon/llenum.h +++ b/linden/indra/llcommon/llenum.h @@ -3,6 +3,8 @@ * @author Tom Yedwab * @brief Utility class for storing enum value <-> string lookup. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLENUM_H diff --git a/linden/indra/llcommon/llerror.cpp b/linden/indra/llcommon/llerror.cpp index 714a265..22b2c9d 100644 --- a/linden/indra/llcommon/llerror.cpp +++ b/linden/indra/llcommon/llerror.cpp @@ -3,6 +3,8 @@ * @date December 2006 * @brief error message system * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -32,34 +35,28 @@ #include "llerror.h" #include "llerrorcontrol.h" -#include "llapp.h" -#include "llapr.h" -extern apr_thread_mutex_t *gLogMutexp; -#include "llfile.h" -#include "llfixedbuffer.h" -#include "lllivefile.h" -#include "llsd.h" -#include "llsdserialize.h" -#include "llstl.h" - -#include #include -#include +#ifdef __GNUC__ +#include +#endif #include #if !LL_WINDOWS -#include #include #endif -#include #if LL_WINDOWS #include #endif #include +#include "llapp.h" +#include "llapr.h" +#include "llfile.h" +#include "llfixedbuffer.h" +#include "lllivefile.h" +#include "llsd.h" +#include "llsdserialize.h" +#include "llstl.h" -#ifdef __GNUC__ -#include -#endif namespace { #if !LL_WINDOWS diff --git a/linden/indra/llcommon/llerror.h b/linden/indra/llcommon/llerror.h index 9c8d018..ae41cd5 100644 --- a/linden/indra/llcommon/llerror.h +++ b/linden/indra/llcommon/llerror.h @@ -3,6 +3,8 @@ * @date December 2006 * @brief error message system * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLERROR_H diff --git a/linden/indra/llcommon/llerrorcontrol.h b/linden/indra/llcommon/llerrorcontrol.h index c09a180..528704d 100644 --- a/linden/indra/llcommon/llerrorcontrol.h +++ b/linden/indra/llcommon/llerrorcontrol.h @@ -3,7 +3,9 @@ * @date December 2006 * @brief error message system control * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLERRORCONTROL_H diff --git a/linden/indra/llcommon/llerrorlegacy.h b/linden/indra/llcommon/llerrorlegacy.h index 1671d0f..cef3455 100644 --- a/linden/indra/llcommon/llerrorlegacy.h +++ b/linden/indra/llcommon/llerrorlegacy.h @@ -3,7 +3,9 @@ * @date January 2007 * @brief old things from the older error system * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLERRORLEGACY_H diff --git a/linden/indra/llcommon/llerrorthread.cpp b/linden/indra/llcommon/llerrorthread.cpp index 5f7d448..66806b4 100644 --- a/linden/indra/llcommon/llerrorthread.cpp +++ b/linden/indra/llcommon/llerrorthread.cpp @@ -1,6 +1,8 @@ /** * @file llerrorthread.cpp * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/llerrorthread.h b/linden/indra/llcommon/llerrorthread.h index 61bcf4c..714f014 100644 --- a/linden/indra/llcommon/llerrorthread.h +++ b/linden/indra/llcommon/llerrorthread.h @@ -2,6 +2,8 @@ * @file llerrorthread.h * @brief Specialized thread to handle runtime errors. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLERRORTHREAD_H diff --git a/linden/indra/llcommon/llevent.cpp b/linden/indra/llcommon/llevent.cpp index 9c736c8..292d090 100644 --- a/linden/indra/llcommon/llevent.cpp +++ b/linden/indra/llcommon/llevent.cpp @@ -2,6 +2,8 @@ * @file llevent.cpp * @brief LLEvent and LLEventListener base classes. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/llevent.h b/linden/indra/llcommon/llevent.h index cab8817..3018cc6 100644 --- a/linden/indra/llcommon/llevent.h +++ b/linden/indra/llcommon/llevent.h @@ -3,6 +3,8 @@ * @author Tom Yedwab * @brief LLEvent and LLEventListener base classes. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_EVENT_H diff --git a/linden/indra/llcommon/lleventemitter.h b/linden/indra/llcommon/lleventemitter.h index 6390d34..4129dab 100644 --- a/linden/indra/llcommon/lleventemitter.h +++ b/linden/indra/llcommon/lleventemitter.h @@ -2,6 +2,8 @@ * @file lleventemitter.h * @brief General event emitter class * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // header guard diff --git a/linden/indra/llcommon/llextendedstatus.h b/linden/indra/llcommon/llextendedstatus.h index a1c998f..e4266f6 100644 --- a/linden/indra/llcommon/llextendedstatus.h +++ b/linden/indra/llcommon/llextendedstatus.h @@ -3,7 +3,9 @@ * @date August 2007 * @brief extended status codes for curl/vfs/resident asset storage and delivery * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLEXTENDEDSTATUS_H diff --git a/linden/indra/llcommon/llfasttimer.cpp b/linden/indra/llcommon/llfasttimer.cpp index 6c0f9ac..9dc5e17 100644 --- a/linden/indra/llcommon/llfasttimer.cpp +++ b/linden/indra/llcommon/llfasttimer.cpp @@ -2,6 +2,8 @@ * @file llfasttimer.cpp * @brief Implementation of the fast timer. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,25 +26,23 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" #include "llfasttimer.h" + #include "llprocessor.h" -#if LL_WINDOWS -#include +#if LL_WINDOWS #elif LL_LINUX || LL_SOLARIS -#include #include #include - #elif LL_DARWIN -# include -# include +#include #else -# error "architecture not supported" +#error "architecture not supported" #endif ////////////////////////////////////////////////////////////////////////////// diff --git a/linden/indra/llcommon/llfasttimer.h b/linden/indra/llcommon/llfasttimer.h index 4182500..08edce4 100644 --- a/linden/indra/llcommon/llfasttimer.h +++ b/linden/indra/llcommon/llfasttimer.h @@ -2,6 +2,8 @@ * @file llfasttimer.h * @brief Declaration of a fast timer. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,13 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFASTTIMER_H #define LL_LLFASTTIMER_H -#include "lltimer.h" - #define FAST_TIMER_ON 1 U64 get_cpu_clock_count(); diff --git a/linden/indra/llcommon/llfile.cpp b/linden/indra/llcommon/llfile.cpp index 6fcfc42..eb76b20 100644 --- a/linden/indra/llcommon/llfile.cpp +++ b/linden/indra/llcommon/llfile.cpp @@ -5,6 +5,8 @@ * @brief Implementation of cross-platform POSIX file buffer and c++ * stream classes. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -27,6 +29,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/llfile.h b/linden/indra/llcommon/llfile.h index 9e1a98a..f51cea9 100644 --- a/linden/indra/llcommon/llfile.h +++ b/linden/indra/llcommon/llfile.h @@ -5,6 +5,8 @@ * @brief Declaration of cross-platform POSIX file buffer and c++ * stream classes. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -27,6 +29,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFILE_H @@ -37,12 +40,6 @@ * Attempts to mostly mirror the POSIX style IO functions. */ -#include -#include -#include -#include -#include "stdtypes.h" - typedef FILE LLFILE; #ifdef LL_WINDOWS @@ -56,6 +53,7 @@ typedef FILE LLFILE; // windows version of stat function and stat data structure are called _stat typedef struct _stat llstat; #else +#include typedef struct stat llstat; #endif diff --git a/linden/indra/llcommon/llfixedbuffer.cpp b/linden/indra/llcommon/llfixedbuffer.cpp index 6defd92..44bb953 100644 --- a/linden/indra/llcommon/llfixedbuffer.cpp +++ b/linden/indra/llcommon/llfixedbuffer.cpp @@ -1,6 +1,8 @@ /** * @file llfixedbuffer.cpp * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/llfixedbuffer.h b/linden/indra/llcommon/llfixedbuffer.h index fbf2338..148c0e6 100644 --- a/linden/indra/llcommon/llfixedbuffer.h +++ b/linden/indra/llcommon/llfixedbuffer.h @@ -2,6 +2,8 @@ * @file llfixedbuffer.h * @brief A fixed size buffer of lines. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFIXEDBUFFER_H diff --git a/linden/indra/llcommon/llformat.cpp b/linden/indra/llcommon/llformat.cpp index 6a5b531..bb0f467 100644 --- a/linden/indra/llcommon/llformat.cpp +++ b/linden/indra/llcommon/llformat.cpp @@ -3,7 +3,9 @@ * @date January 2007 * @brief string formatting utility * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -25,13 +27,14 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" #include "llformat.h" -#include +#include std::string llformat(const char *fmt, ...) { diff --git a/linden/indra/llcommon/llformat.h b/linden/indra/llcommon/llformat.h index b338591..8b8c4a4 100644 --- a/linden/indra/llcommon/llformat.h +++ b/linden/indra/llcommon/llformat.h @@ -3,7 +3,9 @@ * @date January 2007 * @brief string formatting utility * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -25,13 +27,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFORMAT_H #define LL_LLFORMAT_H -#include - // Use as follows: // llinfos << llformat("Test:%d (%.2f %.2f)", idx, x, y) << llendl; // diff --git a/linden/indra/llcommon/llframetimer.cpp b/linden/indra/llcommon/llframetimer.cpp index 2b53e8c..23d8775 100644 --- a/linden/indra/llcommon/llframetimer.cpp +++ b/linden/indra/llcommon/llframetimer.cpp @@ -1,6 +1,8 @@ /** * @file llframetimer.cpp * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/llframetimer.h b/linden/indra/llcommon/llframetimer.h index de550e2..9d55fd1 100644 --- a/linden/indra/llcommon/llframetimer.h +++ b/linden/indra/llcommon/llframetimer.h @@ -3,6 +3,8 @@ * @brief A lightweight timer that measures seconds and is only * updated once per frame. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFRAMETIMER_H diff --git a/linden/indra/llcommon/llhash.h b/linden/indra/llcommon/llhash.h index 793783f..f4b0586 100644 --- a/linden/indra/llcommon/llhash.h +++ b/linden/indra/llcommon/llhash.h @@ -2,6 +2,8 @@ * @file llhash.h * @brief Wrapper for a hash function. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLHASH_H diff --git a/linden/indra/llcommon/llindexedqueue.h b/linden/indra/llcommon/llindexedqueue.h index 13e9f7a..d689f1c 100644 --- a/linden/indra/llcommon/llindexedqueue.h +++ b/linden/indra/llcommon/llindexedqueue.h @@ -3,6 +3,8 @@ * @brief An indexed FIFO queue, where only one element with each key * can be in the queue. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLINDEXEDQUEUE_H diff --git a/linden/indra/llcommon/lllinkedqueue.h b/linden/indra/llcommon/lllinkedqueue.h index 9ce5a1b..dcd13a2 100644 --- a/linden/indra/llcommon/lllinkedqueue.h +++ b/linden/indra/llcommon/lllinkedqueue.h @@ -2,6 +2,8 @@ * @file lllinkedqueue.h * @brief Declaration of linked queue classes. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLLINKEDQUEUE_H diff --git a/linden/indra/llcommon/llliveappconfig.cpp b/linden/indra/llcommon/llliveappconfig.cpp index 7923126..7643277 100644 --- a/linden/indra/llcommon/llliveappconfig.cpp +++ b/linden/indra/llcommon/llliveappconfig.cpp @@ -2,6 +2,8 @@ * @file llliveappconfig.cpp * @brief Configuration information for an LLApp that overrides indra.xml * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/llliveappconfig.h b/linden/indra/llcommon/llliveappconfig.h index f5c73d0..dd6dbfb 100644 --- a/linden/indra/llcommon/llliveappconfig.h +++ b/linden/indra/llcommon/llliveappconfig.h @@ -2,6 +2,8 @@ * @file llliveappconfig.h * @brief Configuration information for an LLApp that overrides indra.xml * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLLIVEAPPCONFIG_H diff --git a/linden/indra/llcommon/lllivefile.cpp b/linden/indra/llcommon/lllivefile.cpp index 17fe210..cb3ce0f 100644 --- a/linden/indra/llcommon/lllivefile.cpp +++ b/linden/indra/llcommon/lllivefile.cpp @@ -1,6 +1,8 @@ /** * @file lllivefile.cpp * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/lllivefile.h b/linden/indra/llcommon/lllivefile.h index d8381bf..689590e 100644 --- a/linden/indra/llcommon/lllivefile.h +++ b/linden/indra/llcommon/lllivefile.h @@ -2,6 +2,8 @@ * @file lllivefile.h * @brief Automatically reloads a file whenever it changes or is removed. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLLIVEFILE_H diff --git a/linden/indra/llcommon/lllocalidhashmap.h b/linden/indra/llcommon/lllocalidhashmap.h index aae0bd9..12df73d 100644 --- a/linden/indra/llcommon/lllocalidhashmap.h +++ b/linden/indra/llcommon/lllocalidhashmap.h @@ -2,6 +2,8 @@ * @file lllocalidhashmap.h * @brief Map specialized for dealing with local ids * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLLOCALIDHASHMAP_H diff --git a/linden/indra/llcommon/lllslconstants.h b/linden/indra/llcommon/lllslconstants.h index 372c54e..c970161 100644 --- a/linden/indra/llcommon/lllslconstants.h +++ b/linden/indra/llcommon/lllslconstants.h @@ -3,6 +3,8 @@ * @author James Cook * @brief Constants used in lsl. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLLSLCONSTANTS_H diff --git a/linden/indra/llcommon/llmap.h b/linden/indra/llcommon/llmap.h index 65e3da7..9ad93b2 100644 --- a/linden/indra/llcommon/llmap.h +++ b/linden/indra/llcommon/llmap.h @@ -2,6 +2,8 @@ * @file llmap.h * @brief LLMap class header file * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,15 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMAP_H #define LL_LLMAP_H -#include -#include -#include - // llmap uses the fast stl library code in a manner consistant with LLSkipMap, et. al. template class LLMap diff --git a/linden/indra/llcommon/llmemory.cpp b/linden/indra/llcommon/llmemory.cpp index 65f3409..e52a137 100644 --- a/linden/indra/llcommon/llmemory.cpp +++ b/linden/indra/llcommon/llmemory.cpp @@ -2,6 +2,8 @@ * @file llmemory.cpp * @brief Very special memory allocation/deallocation stuff here * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,10 +26,26 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" +#if defined(LL_WINDOWS) +# include +# include +#elif defined(LL_DARWIN) +# include +# include +# include +# include +# include +# include +# include +#elif defined(LL_LINUX) +# include +#endif + #include "llmemory.h" #include "llmemtype.h" @@ -278,3 +296,131 @@ LLRefCount::~LLRefCount() //---------------------------------------------------------------------------- +#if defined(LL_WINDOWS) + +U64 getCurrentRSS() +{ + HANDLE self = GetCurrentProcess(); + PROCESS_MEMORY_COUNTERS counters; + + if (!GetProcessMemoryInfo(self, &counters, sizeof(counters))) + { + llwarns << "GetProcessMemoryInfo failed" << llendl; + return 0; + } + + return counters.WorkingSetSize; +} + +#elif defined(LL_DARWIN) + +static U32 getPageSize() +{ + int ctl[2] = { CTL_HW, HW_PAGESIZE }; + int page_size; + size_t size = sizeof(page_size); + + if (sysctl(ctl, 2, &page_size, &size, NULL, 0) == -1) + { + llwarns << "Couldn't get page size" << llendl; + return 0; + } else { + return page_size; + } +} + +U64 getCurrentRSS() +{ + task_t task = mach_task_self(); + vm_address_t addr = VM_MIN_ADDRESS; + vm_size_t size = 0; + U64 residentPages = 0; + + while (true) + { + mach_msg_type_number_t bcount = VM_REGION_BASIC_INFO_COUNT; + vm_region_basic_info binfo; + mach_port_t bobj; + kern_return_t ret; + + addr += size; + + ret = vm_region(task, &addr, &size, VM_REGION_BASIC_INFO, + (vm_region_info_t) &binfo, &bcount, &bobj); + + if (ret != KERN_SUCCESS) + { + break; + } + + if (bobj != MACH_PORT_NULL) + { + mach_port_deallocate(task, bobj); + } + + mach_msg_type_number_t ecount = VM_REGION_EXTENDED_INFO_COUNT; + vm_region_extended_info einfo; + mach_port_t eobj; + + ret = vm_region(task, &addr, &size, VM_REGION_EXTENDED_INFO, + (vm_region_info_t) &einfo, &ecount, &eobj); + + if (ret != KERN_SUCCESS) + { + llwarns << "vm_region failed" << llendl; + return 0; + } + + if (eobj != MACH_PORT_NULL) + { + mach_port_deallocate(task, eobj); + } + + residentPages += einfo.pages_resident; + } + + return residentPages * getPageSize(); +} + +#elif defined(LL_LINUX) + +U64 getCurrentRSS() +{ + static const char statPath[] = "/proc/self/stat"; + FILE *fp = fopen(statPath, "r"); + U64 rss = 0; + + if (fp == NULL) + { + llwarns << "couldn't open " << statPath << llendl; + goto bail; + } + + // Eee-yew! See Documentation/filesystems/proc.txt in your + // nearest friendly kernel tree for details. + + { + int ret = fscanf(fp, "%*d (%*[^)]) %*c %*d %*d %*d %*d %*d %*d %*d " + "%*d %*d %*d %*d %*d %*d %*d %*d %*d %*d %*d %Lu", + &rss); + if (ret != 1) + { + llwarns << "couldn't parse contents of " << statPath << llendl; + rss = 0; + } + } + + fclose(fp); + +bail: + return rss; +} + +#else + +U64 getCurrentRSS() +{ + return 0; +} + +#endif diff --git a/linden/indra/llcommon/llmemory.h b/linden/indra/llcommon/llmemory.h index b6f42e3..b72046c 100644 --- a/linden/indra/llcommon/llmemory.h +++ b/linden/indra/llcommon/llmemory.h @@ -2,6 +2,8 @@ * @file llmemory.h * @brief Memory allocation/deallocation header-stuff goes here. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_MEMORY_H #define LL_MEMORY_H @@ -415,5 +418,8 @@ public: //---------------------------------------------------------------------------- -#endif +// Return the resident set size of the current process, in bytes. +// Return value is zero if not known. +U64 getCurrentRSS(); +#endif diff --git a/linden/indra/llcommon/llmemorystream.cpp b/linden/indra/llcommon/llmemorystream.cpp index ac9e61c..e487252 100644 --- a/linden/indra/llcommon/llmemorystream.cpp +++ b/linden/indra/llcommon/llmemorystream.cpp @@ -4,6 +4,8 @@ * @date 2005-06-03 * @brief Buffer and stream for a fixed linear memory segment. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/llmemorystream.h b/linden/indra/llcommon/llmemorystream.h index f00bc28..317e86d 100644 --- a/linden/indra/llcommon/llmemorystream.h +++ b/linden/indra/llcommon/llmemorystream.h @@ -4,6 +4,8 @@ * @date 2005-06-03 * @brief Implementation of a simple fixed memory stream * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMEMORYSTREAM_H diff --git a/linden/indra/llcommon/llmemtype.h b/linden/indra/llcommon/llmemtype.h index 9bab72e..9bf6cad 100644 --- a/linden/indra/llcommon/llmemtype.h +++ b/linden/indra/llcommon/llmemtype.h @@ -2,6 +2,8 @@ * @file llmemtype.h * @brief Runtime memory usage debugging utilities. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_MEMTYPE_H diff --git a/linden/indra/llcommon/llmetrics.cpp b/linden/indra/llcommon/llmetrics.cpp index 74bd13d..90a0517 100644 --- a/linden/indra/llcommon/llmetrics.cpp +++ b/linden/indra/llcommon/llmetrics.cpp @@ -4,7 +4,9 @@ * @date 2007-05-25 * @brief Metrics accumulation and associated functions * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/llmetrics.h b/linden/indra/llcommon/llmetrics.h index 2c216c3..f19bce5 100644 --- a/linden/indra/llcommon/llmetrics.h +++ b/linden/indra/llcommon/llmetrics.h @@ -4,7 +4,9 @@ * @date 2007-05-25 * @brief Declaration of metrics accumulation and associated functions * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMETRICS_H diff --git a/linden/indra/llcommon/llmortician.cpp b/linden/indra/llcommon/llmortician.cpp index be362bf..cab3a7f 100644 --- a/linden/indra/llcommon/llmortician.cpp +++ b/linden/indra/llcommon/llmortician.cpp @@ -1,6 +1,8 @@ /** * @file llmortician.cpp * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/llmortician.h b/linden/indra/llcommon/llmortician.h index 353f263..24a3852 100644 --- a/linden/indra/llcommon/llmortician.h +++ b/linden/indra/llcommon/llmortician.h @@ -2,6 +2,8 @@ * @file llmortician.h * @brief Base class for delayed deletions. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLMORTICIAN_H diff --git a/linden/indra/llcommon/llnametable.h b/linden/indra/llcommon/llnametable.h index c3bdfbd..fd6f879 100644 --- a/linden/indra/llcommon/llnametable.h +++ b/linden/indra/llcommon/llnametable.h @@ -2,6 +2,8 @@ * @file llnametable.h * @brief LLNameTable class is a table to associate pointers with string names * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLNAMETABLE_H diff --git a/linden/indra/llcommon/llpreprocessor.h b/linden/indra/llcommon/llpreprocessor.h index f19d5a0..b3b79d0 100644 --- a/linden/indra/llcommon/llpreprocessor.h +++ b/linden/indra/llcommon/llpreprocessor.h @@ -3,6 +3,8 @@ * @brief This file should be included in all Linden Lab files and * should only contain special preprocessor directives * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLPREPROCESSOR_H diff --git a/linden/indra/llcommon/llpriqueuemap.h b/linden/indra/llcommon/llpriqueuemap.h index deda338..96da935 100644 --- a/linden/indra/llcommon/llpriqueuemap.h +++ b/linden/indra/llcommon/llpriqueuemap.h @@ -2,6 +2,8 @@ * @file llpriqueuemap.h * @brief Priority queue implementation * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPRIQUEUEMAP_H #define LL_LLPRIQUEUEMAP_H diff --git a/linden/indra/llcommon/llprocessor.cpp b/linden/indra/llcommon/llprocessor.cpp index 4d00ab5..4977ead 100644 --- a/linden/indra/llcommon/llprocessor.cpp +++ b/linden/indra/llcommon/llprocessor.cpp @@ -2,6 +2,8 @@ * @file llprocessor.cpp * @brief Code to figure out the processor. Originally by Benjamin Jurke. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Filename: Processor.cpp @@ -48,9 +51,7 @@ #include "processor.h" -#include -#include -#include +#include #if LL_WINDOWS # define WIN32_LEAN_AND_MEAN diff --git a/linden/indra/llcommon/llprocessor.h b/linden/indra/llcommon/llprocessor.h index 79dd1e8..6b966c5 100644 --- a/linden/indra/llcommon/llprocessor.h +++ b/linden/indra/llcommon/llprocessor.h @@ -2,6 +2,8 @@ * @file llprocessor.h * @brief Code to figure out the processor. Originally by Benjamin Jurke. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Author: Benjamin Jurke diff --git a/linden/indra/llcommon/llptrskiplist.h b/linden/indra/llcommon/llptrskiplist.h index f695f88..81c8ca3 100644 --- a/linden/indra/llcommon/llptrskiplist.h +++ b/linden/indra/llcommon/llptrskiplist.h @@ -2,6 +2,8 @@ * @file llptrskiplist.h * @brief Skip list implementation. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPTRSKIPLIST_H diff --git a/linden/indra/llcommon/llptrskipmap.h b/linden/indra/llcommon/llptrskipmap.h index e2fdc7f..e505004 100644 --- a/linden/indra/llcommon/llptrskipmap.h +++ b/linden/indra/llcommon/llptrskipmap.h @@ -3,6 +3,8 @@ * @brief Just like a LLSkipMap, but since it's pointers, you can call * deleteAllData * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPTRSKIPMAP_H #define LL_LLPTRSKIPMAP_H diff --git a/linden/indra/llcommon/llqueuedthread.cpp b/linden/indra/llcommon/llqueuedthread.cpp index 7eaaf68..8dfba0b 100644 --- a/linden/indra/llcommon/llqueuedthread.cpp +++ b/linden/indra/llcommon/llqueuedthread.cpp @@ -1,6 +1,8 @@ /** * @file llqueuedthread.cpp * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/llqueuedthread.h b/linden/indra/llcommon/llqueuedthread.h index 18a44c5..a5919c8 100644 --- a/linden/indra/llcommon/llqueuedthread.h +++ b/linden/indra/llcommon/llqueuedthread.h @@ -2,6 +2,8 @@ * @file llqueuedthread.h * @brief * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLQUEUEDTHREAD_H diff --git a/linden/indra/llcommon/llrun.cpp b/linden/indra/llcommon/llrun.cpp index 131030e..5d0e98a 100644 --- a/linden/indra/llcommon/llrun.cpp +++ b/linden/indra/llcommon/llrun.cpp @@ -4,6 +4,8 @@ * @date 2006-02-16 * @brief Implementation of the LLRunner and related classes * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/llrun.h b/linden/indra/llcommon/llrun.h index 649c7b0..1c9f6c1 100644 --- a/linden/indra/llcommon/llrun.h +++ b/linden/indra/llcommon/llrun.h @@ -4,6 +4,8 @@ * @date 2006-02-16 * @brief Declaration of LLRunner and LLRunnable classes. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLRUN_H diff --git a/linden/indra/llcommon/llsd.cpp b/linden/indra/llcommon/llsd.cpp index f6d8d0e..305531b 100644 --- a/linden/indra/llcommon/llsd.cpp +++ b/linden/indra/llcommon/llsd.cpp @@ -2,6 +2,8 @@ * @file llsd.cpp * @brief LLSD flexible data system * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,14 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" #include "llsd.h" -#include -#include - #include "llerror.h" #include "../llmath/llmath.h" #include "llformat.h" diff --git a/linden/indra/llcommon/llsd.h b/linden/indra/llcommon/llsd.h index bd24ecf..1fb917f 100644 --- a/linden/indra/llcommon/llsd.h +++ b/linden/indra/llcommon/llsd.h @@ -2,6 +2,8 @@ * @file llsd.h * @brief LLSD flexible data system. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSD_NEW_H diff --git a/linden/indra/llcommon/llsdserialize.cpp b/linden/indra/llcommon/llsdserialize.cpp index d262ca1..a7470be 100644 --- a/linden/indra/llcommon/llsdserialize.cpp +++ b/linden/indra/llcommon/llsdserialize.cpp @@ -4,6 +4,8 @@ * @date 2006-03-05 * @brief Implementation of LLSD parsers and formatters * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/llsdserialize.h b/linden/indra/llcommon/llsdserialize.h index 4a73b60..b4d6683 100644 --- a/linden/indra/llcommon/llsdserialize.h +++ b/linden/indra/llcommon/llsdserialize.h @@ -4,6 +4,8 @@ * @date 2006-02-26 * @brief Declaration of parsers and formatters for LLSD * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSDSERIALIZE_H diff --git a/linden/indra/llcommon/llsdserialize_xml.cpp b/linden/indra/llcommon/llsdserialize_xml.cpp index 6d2f583..6232622 100644 --- a/linden/indra/llcommon/llsdserialize_xml.cpp +++ b/linden/indra/llcommon/llsdserialize_xml.cpp @@ -2,6 +2,8 @@ * @file llsdserialize_xml.cpp * @brief XML parsers and formatters for LLSD * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/llsdserialize_xml.h b/linden/indra/llcommon/llsdserialize_xml.h index 0546ea4..bb55a46 100644 --- a/linden/indra/llcommon/llsdserialize_xml.h +++ b/linden/indra/llcommon/llsdserialize_xml.h @@ -2,6 +2,8 @@ * @file llsdserialize_xml.h * @brief XML parsers and formatters for LLSD * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSDSERIALIZE_XML_H diff --git a/linden/indra/llcommon/llsdutil.cpp b/linden/indra/llcommon/llsdutil.cpp index 0e23054..a0f337c 100644 --- a/linden/indra/llcommon/llsdutil.cpp +++ b/linden/indra/llcommon/llsdutil.cpp @@ -4,6 +4,8 @@ * @date 2006-05-24 * @brief Implementation of classes, functions, etc, for using structured data. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/llsdutil.h b/linden/indra/llcommon/llsdutil.h index 38a7b83..699d509 100644 --- a/linden/indra/llcommon/llsdutil.h +++ b/linden/indra/llcommon/llsdutil.h @@ -4,6 +4,8 @@ * @date 2006-05-24 * @brief Utility classes, functions, etc, for using structured data. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSDUTIL_H diff --git a/linden/indra/llcommon/llsecondlifeurls.cpp b/linden/indra/llcommon/llsecondlifeurls.cpp index 53a1906..4417b09 100644 --- a/linden/indra/llcommon/llsecondlifeurls.cpp +++ b/linden/indra/llcommon/llsecondlifeurls.cpp @@ -2,6 +2,8 @@ * @file llsecondlifeurls.cpp * @brief Urls used in the product * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/llsecondlifeurls.h b/linden/indra/llcommon/llsecondlifeurls.h index d4d296b..0eb3d64 100644 --- a/linden/indra/llcommon/llsecondlifeurls.h +++ b/linden/indra/llcommon/llsecondlifeurls.h @@ -2,6 +2,8 @@ * @file llsecondlifeurls.h * @brief Global URLs to pages on our web site * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSECONDLIFEURLS_H diff --git a/linden/indra/llcommon/llsimplehash.h b/linden/indra/llcommon/llsimplehash.h index 4e0d5ea..ae5a31e 100644 --- a/linden/indra/llcommon/llsimplehash.h +++ b/linden/indra/llcommon/llsimplehash.h @@ -1,6 +1,8 @@ /** * @file llsimplehash.h * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSIMPLEHASH_H diff --git a/linden/indra/llcommon/llskiplist.h b/linden/indra/llcommon/llskiplist.h index 40d0c8a..314043e 100644 --- a/linden/indra/llcommon/llskiplist.h +++ b/linden/indra/llcommon/llskiplist.h @@ -2,6 +2,8 @@ * @file llskiplist.h * @brief skip list implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSKIPLIST_H #define LL_LLSKIPLIST_H diff --git a/linden/indra/llcommon/llskipmap.h b/linden/indra/llcommon/llskipmap.h index c2c0092..65e1617 100644 --- a/linden/indra/llcommon/llskipmap.h +++ b/linden/indra/llcommon/llskipmap.h @@ -2,6 +2,8 @@ * @file llskipmap.h * @brief Associative container based on the skiplist algorithm. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSKIPMAP_H diff --git a/linden/indra/llcommon/llstack.h b/linden/indra/llcommon/llstack.h index 36c2e1e..5fb65f2 100644 --- a/linden/indra/llcommon/llstack.h +++ b/linden/indra/llcommon/llstack.h @@ -2,6 +2,8 @@ * @file llstack.h * @brief LLStack template class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSTACK_H diff --git a/linden/indra/llcommon/llstat.cpp b/linden/indra/llcommon/llstat.cpp index 7e6090f..e999934 100644 --- a/linden/indra/llcommon/llstat.cpp +++ b/linden/indra/llcommon/llstat.cpp @@ -1,6 +1,8 @@ /** * @file llstat.cpp * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/llstat.h b/linden/indra/llcommon/llstat.h index 9266b60..e20c01f 100644 --- a/linden/indra/llcommon/llstat.h +++ b/linden/indra/llcommon/llstat.h @@ -2,6 +2,8 @@ * @file llstat.h * @brief Runtime statistics accumulation. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSTAT_H diff --git a/linden/indra/llcommon/llstatenums.h b/linden/indra/llcommon/llstatenums.h index fc618df..e9876f8 100644 --- a/linden/indra/llcommon/llstatenums.h +++ b/linden/indra/llcommon/llstatenums.h @@ -1,6 +1,8 @@ /** * @file llstatenums.h * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSTATENUMS_H diff --git a/linden/indra/llcommon/llstl.h b/linden/indra/llcommon/llstl.h index 06980a1..b692dae 100644 --- a/linden/indra/llcommon/llstl.h +++ b/linden/indra/llcommon/llstl.h @@ -2,6 +2,8 @@ * @file llstl.h * @brief helper object & functions for use with the stl. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,21 +26,16 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSTL_H #define LL_LLSTL_H #include -#include -#include -#include #include #include -#include -#include - // Use to compare the first element only of a pair // e.g. typedef std::set, compare_pair > some_pair_set_t; template diff --git a/linden/indra/llcommon/llstreamtools.cpp b/linden/indra/llcommon/llstreamtools.cpp index e6cd909..bfe1765 100644 --- a/linden/indra/llcommon/llstreamtools.cpp +++ b/linden/indra/llcommon/llstreamtools.cpp @@ -2,6 +2,8 @@ * @file llstreamtools.cpp * @brief some helper functions for parsing legacy simstate and asset files. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/llstreamtools.h b/linden/indra/llcommon/llstreamtools.h index d64bd57..0708447 100644 --- a/linden/indra/llcommon/llstreamtools.h +++ b/linden/indra/llcommon/llstreamtools.h @@ -2,6 +2,8 @@ * @file llstreamtools.h * @brief some helper functions for parsing legacy simstate and asset files. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_STREAM_TOOLS_H diff --git a/linden/indra/llcommon/llstrider.h b/linden/indra/llcommon/llstrider.h index 707d10e..e619ceb 100644 --- a/linden/indra/llcommon/llstrider.h +++ b/linden/indra/llcommon/llstrider.h @@ -1,6 +1,8 @@ /** * @file llstrider.h * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSTRIDER_H diff --git a/linden/indra/llcommon/llstring.cpp b/linden/indra/llcommon/llstring.cpp index b5e307f..6dab598 100644 --- a/linden/indra/llcommon/llstring.cpp +++ b/linden/indra/llcommon/llstring.cpp @@ -2,6 +2,8 @@ * @file llstring.cpp * @brief String utility functions and the LLString class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -55,6 +58,26 @@ U8 hex_as_nybble(char hex) } +bool _read_file_into_string(std::string& str, const char* filename) +{ + llifstream ifs(filename, llifstream::binary); + if (!ifs.is_open()) + { + llinfos << "Unable to open file" << filename << llendl; + return false; + } + + std::ostringstream oss; + + oss << ifs.rdbuf(); + str = oss.str(); + ifs.close(); + return true; +} + + + + // See http://www.unicode.org/Public/BETA/CVTUTF-1-2/ConvertUTF.c // for the Unicode implementation - this doesn't match because it was written before finding // it. diff --git a/linden/indra/llcommon/llstring.h b/linden/indra/llcommon/llstring.h index 5f48580..70f7d54 100644 --- a/linden/indra/llcommon/llstring.h +++ b/linden/indra/llcommon/llstring.h @@ -2,6 +2,8 @@ * @file llstring.h * @brief String utility functions and LLString class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,22 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSTRING_H #define LL_LLSTRING_H -#include "stdtypes.h" -#include "llerror.h" -#include "llfile.h" -#include -#include -#include -#include -#include -#include -#include -#include /* for vsnprintf */ #if LL_LINUX || LL_SOLARIS #include #include @@ -280,9 +272,6 @@ public: */ static void _makeASCII(std::basic_string& string); - static BOOL read(std::basic_string& string, const char* filename); /*Flawfinder: ignore*/ - static BOOL write(std::basic_string& string, const char* filename); - // Conversion to other data types static BOOL convertToBOOL(const std::basic_string& string, BOOL& value); static BOOL convertToU8(const std::basic_string& string, U8& value); @@ -332,6 +321,18 @@ template LLStringBase LLStringBase::null; typedef LLStringBase LLString; typedef LLStringBase LLWString; +//@ Use this where we want to disallow input in the form of "foo" +// This is used to catch places where english text is embedded in the code +// instead of in a translatable XUI file. +class LLStringExplicit : public LLString +{ +public: + explicit LLStringExplicit(const char* s) : LLString(s) {} + LLStringExplicit(const LLString& s) : LLString(s) {} + LLStringExplicit(const std::string& s) : LLString(s) {} + LLStringExplicit(const std::string& s, size_type pos, size_type n = std::string::npos) : LLString(s, pos, n) {} +}; + struct LLDictionaryLess { public: @@ -347,7 +348,7 @@ public: */ /** - * @breif chop off the trailing characters in a string. + * @brief chop off the trailing characters in a string. * * This function works on bytes rather than glyphs, so this will * incorrectly truncate non-single byte strings. @@ -373,6 +374,16 @@ std::string ll_safe_string(const char* in); */ U8 hex_as_nybble(char hex); +/** + * @brief read the contents of a file into a string. + * + * Since this function has no concept of character encoding, most + * anything you do with this method ill-advised. Please avoid. + * @param str [out] The string which will have. + * @param filename The full name of the file to read. + * @return Returns true on success. If false, str is unmodified. + */ +bool _read_file_into_string(std::string& str, const char* filename); /** * Unicode support @@ -933,8 +944,6 @@ void LLStringBase::replaceNonstandardASCII( std::basic_string& string, T r template void LLStringBase::replaceTabsWithSpaces( std::basic_string& str, size_type spaces_per_tab ) { - llassert( spaces_per_tab >= 0 ); - const T TAB = '\t'; const T SPACE = ' '; @@ -1037,11 +1046,10 @@ void LLStringBase::copy( T* dst, const T* src, size_type dst_size ) template void LLStringBase::copyInto(std::basic_string& dst, const std::basic_string& src, size_type offset) { - llassert( offset <= dst.length() ); - - // special case - append to end of string and avoid expensive (when strings are large) string manipulations if ( offset == dst.length() ) { + // special case - append to end of string and avoid expensive + // (when strings are large) string manipulations dst += src; } else @@ -1070,48 +1078,6 @@ BOOL LLStringBase::isHead( const std::basic_string& string, const T* s ) } } -//static -template -BOOL LLStringBase::read(std::basic_string& string, const char* filename) /*Flawfinder: ignore*/ -{ - llifstream ifs(filename, llifstream::binary); - if (!ifs.is_open()) - { - llinfos << "Unable to open file" << filename << llendl; - return FALSE; - } - - std::basic_ostringstream oss; - - oss << ifs.rdbuf(); - - string = oss.str(); - - ifs.close(); - return TRUE; -} - -//static -template -BOOL LLStringBase::write(std::basic_string& string, const char* filename) -{ -#if LL_LINUX || LL_SOLARIS - printf("STUBBED: LLStringBase::write at %s:%d\n", __FILE__, __LINE__); -#else - llofstream ofs(filename, llofstream::binary); - if (!ofs.is_open()) - { - llinfos << "Unable to open file" << filename << llendl; - return FALSE; - } - - ofs << string; - - ofs.close(); -#endif - return TRUE; -} - template BOOL LLStringBase::convertToBOOL(const std::basic_string& string, BOOL& value) { diff --git a/linden/indra/llcommon/llstringtable.cpp b/linden/indra/llcommon/llstringtable.cpp index 30db4f7..f6da802 100644 --- a/linden/indra/llcommon/llstringtable.cpp +++ b/linden/indra/llcommon/llstringtable.cpp @@ -3,6 +3,8 @@ * @brief The LLStringTable class provides a _fast_ method for finding * unique copies of strings. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/llstringtable.h b/linden/indra/llcommon/llstringtable.h index 8d91680..b7412ef 100644 --- a/linden/indra/llcommon/llstringtable.h +++ b/linden/indra/llcommon/llstringtable.h @@ -3,6 +3,8 @@ * @brief The LLStringTable class provides a _fast_ method for finding * unique copies of strings. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_STRING_TABLE_H diff --git a/linden/indra/llcommon/llsys.cpp b/linden/indra/llcommon/llsys.cpp index 95b6b55..3b57db7 100644 --- a/linden/indra/llcommon/llsys.cpp +++ b/linden/indra/llcommon/llsys.cpp @@ -2,6 +2,8 @@ * @file llsys.cpp * @brief Impelementation of the basic system query functions. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -44,10 +47,12 @@ # include # include #elif LL_DARWIN +# include # include # include # include #elif LL_LINUX +# include # include # include # include diff --git a/linden/indra/llcommon/llsys.h b/linden/indra/llcommon/llsys.h index 66a3465..fc4e027 100644 --- a/linden/indra/llcommon/llsys.h +++ b/linden/indra/llcommon/llsys.h @@ -2,6 +2,8 @@ * @file llsys.h * @brief System information debugging classes. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_SYS_H diff --git a/linden/indra/llcommon/llthread.cpp b/linden/indra/llcommon/llthread.cpp index d261c8b..ea877bd 100644 --- a/linden/indra/llcommon/llthread.cpp +++ b/linden/indra/llcommon/llthread.cpp @@ -1,6 +1,8 @@ /** * @file llthread.cpp * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -266,7 +269,7 @@ LLMutex::LLMutex(apr_pool_t *poolp) : mIsLocalPool = TRUE; apr_pool_create(&mAPRPoolp, NULL); // Create a subpool for this thread } - apr_thread_mutex_create(&mAPRMutexp, APR_THREAD_MUTEX_DEFAULT, mAPRPoolp); + apr_thread_mutex_create(&mAPRMutexp, APR_THREAD_MUTEX_UNNESTED, mAPRPoolp); } diff --git a/linden/indra/llcommon/llthread.h b/linden/indra/llcommon/llthread.h index d700592..8106c08 100644 --- a/linden/indra/llcommon/llthread.h +++ b/linden/indra/llcommon/llthread.h @@ -2,6 +2,8 @@ * @file llthread.h * @brief Base classes for thread, mutex and condition handling. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTHREAD_H diff --git a/linden/indra/llcommon/lltimer.cpp b/linden/indra/llcommon/lltimer.cpp index 177f1de..9786d44 100644 --- a/linden/indra/llcommon/lltimer.cpp +++ b/linden/indra/llcommon/lltimer.cpp @@ -2,6 +2,8 @@ * @file lltimer.cpp * @brief Cross-platform objects for doing timing * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -36,13 +39,10 @@ # define WIN32_LEAN_AND_MEAN # include # include -# include #elif LL_LINUX || LL_SOLARIS -# include # include # include #elif LL_DARWIN -# include # include #else # error "architecture not supported" diff --git a/linden/indra/llcommon/lltimer.h b/linden/indra/llcommon/lltimer.h index 35f0a7b..4ffb9c8 100644 --- a/linden/indra/llcommon/lltimer.h +++ b/linden/indra/llcommon/lltimer.h @@ -2,6 +2,8 @@ * @file lltimer.h * @brief Cross-platform objects for doing timing * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,18 +26,16 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_TIMER_H #define LL_TIMER_H #if LL_LINUX || LL_DARWIN -# include -# include +#include #endif -#include - // units conversions #ifndef USEC_PER_SEC const U32 USEC_PER_SEC = 1000000; diff --git a/linden/indra/llcommon/lluri.cpp b/linden/indra/llcommon/lluri.cpp index 892ac02..df79043 100644 --- a/linden/indra/llcommon/lluri.cpp +++ b/linden/indra/llcommon/lluri.cpp @@ -4,6 +4,8 @@ * @date 2006-02-08 * @brief Implementation of the LLURI class. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/lluri.h b/linden/indra/llcommon/lluri.h index 1044c48..3246dcd 100644 --- a/linden/indra/llcommon/lluri.h +++ b/linden/indra/llcommon/lluri.h @@ -4,6 +4,8 @@ * @date 2006-02-05 * @brief Declaration of the URI class. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLURI_H diff --git a/linden/indra/llcommon/lluuidhashmap.h b/linden/indra/llcommon/lluuidhashmap.h index 77609e0..d8d3cff 100644 --- a/linden/indra/llcommon/lluuidhashmap.h +++ b/linden/indra/llcommon/lluuidhashmap.h @@ -2,6 +2,8 @@ * @file lluuidhashmap.h * @brief A uuid based hash map. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLUUIDHASHMAP_H diff --git a/linden/indra/llcommon/llversionserver.h b/linden/indra/llcommon/llversionserver.h index 0680501..8891b47 100644 --- a/linden/indra/llcommon/llversionserver.h +++ b/linden/indra/llcommon/llversionserver.h @@ -2,6 +2,8 @@ * @file llversionserver.h * @brief * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVERSIONSERVER_H @@ -31,7 +34,7 @@ const S32 LL_VERSION_MAJOR = 1; const S32 LL_VERSION_MINOR = 18; -const S32 LL_VERSION_PATCH = 2; +const S32 LL_VERSION_PATCH = 4; const S32 LL_VERSION_BUILD = 0; const char * const LL_CHANNEL = "Second Life Server"; diff --git a/linden/indra/llcommon/llversionviewer.h b/linden/indra/llcommon/llversionviewer.h index 747381f..46573f4 100644 --- a/linden/indra/llcommon/llversionviewer.h +++ b/linden/indra/llcommon/llversionviewer.h @@ -2,6 +2,8 @@ * @file llversionviewer.h * @brief * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVERSIONVIEWER_H @@ -31,8 +34,8 @@ const S32 LL_VERSION_MAJOR = 1; const S32 LL_VERSION_MINOR = 18; -const S32 LL_VERSION_PATCH = 3; -const S32 LL_VERSION_BUILD = 5; +const S32 LL_VERSION_PATCH = 4; +const S32 LL_VERSION_BUILD = 0; const char * const LL_CHANNEL = "Second Life Release"; diff --git a/linden/indra/llcommon/llworkerthread.cpp b/linden/indra/llcommon/llworkerthread.cpp index b4d9485..d828ed9 100644 --- a/linden/indra/llcommon/llworkerthread.cpp +++ b/linden/indra/llcommon/llworkerthread.cpp @@ -1,6 +1,8 @@ /** * @file llworkerthread.cpp * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/llworkerthread.h b/linden/indra/llcommon/llworkerthread.h index 278f8e0..be06bc2 100644 --- a/linden/indra/llcommon/llworkerthread.h +++ b/linden/indra/llcommon/llworkerthread.h @@ -1,6 +1,8 @@ /** * @file llworkerthread.h * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLWORKERTHREAD_H diff --git a/linden/indra/llcommon/metaclass.cpp b/linden/indra/llcommon/metaclass.cpp index e545411..aa62cef 100644 --- a/linden/indra/llcommon/metaclass.cpp +++ b/linden/indra/llcommon/metaclass.cpp @@ -4,6 +4,8 @@ * @date 2006-05-15 * @brief Implementation of LLMetaClass * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/metaclass.h b/linden/indra/llcommon/metaclass.h index 1e255b0..fa22107 100644 --- a/linden/indra/llcommon/metaclass.h +++ b/linden/indra/llcommon/metaclass.h @@ -4,6 +4,8 @@ * @date 2006-05-15 * @brief Reflective meta information describing a class. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_METACLASS_H diff --git a/linden/indra/llcommon/metaclasst.h b/linden/indra/llcommon/metaclasst.h index 5a110ba..d8d10bd 100644 --- a/linden/indra/llcommon/metaclasst.h +++ b/linden/indra/llcommon/metaclasst.h @@ -1,6 +1,8 @@ /** * @file metaclasst.h * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_METACLASST_H diff --git a/linden/indra/llcommon/metaproperty.cpp b/linden/indra/llcommon/metaproperty.cpp index 221f7a7..fb4720f 100644 --- a/linden/indra/llcommon/metaproperty.cpp +++ b/linden/indra/llcommon/metaproperty.cpp @@ -4,6 +4,8 @@ * @date 2006-05-15 * @brief Implementation of LLMetaProperty. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/metaproperty.h b/linden/indra/llcommon/metaproperty.h index d8272fe..9664e99 100644 --- a/linden/indra/llcommon/metaproperty.h +++ b/linden/indra/llcommon/metaproperty.h @@ -4,6 +4,8 @@ * @date 2006-05-15 * @brief Reflective meta information describing a property of a class. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_METAPROPERTY_H diff --git a/linden/indra/llcommon/metapropertyt.h b/linden/indra/llcommon/metapropertyt.h index 1b444bd..488a60c 100644 --- a/linden/indra/llcommon/metapropertyt.h +++ b/linden/indra/llcommon/metapropertyt.h @@ -1,6 +1,8 @@ /** * @file metapropertyt.h * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_METAPROPERTYT_H diff --git a/linden/indra/llcommon/processor.h b/linden/indra/llcommon/processor.h index 34d970e..af8af40 100644 --- a/linden/indra/llcommon/processor.h +++ b/linden/indra/llcommon/processor.h @@ -2,6 +2,8 @@ * @file processor.h * @brief Legacy wrapper header. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llprocessor.h" diff --git a/linden/indra/llcommon/reflective.cpp b/linden/indra/llcommon/reflective.cpp index c8050e0..942ed0e 100644 --- a/linden/indra/llcommon/reflective.cpp +++ b/linden/indra/llcommon/reflective.cpp @@ -4,6 +4,8 @@ * @date 2006-05-15 * @brief Implementation of LLReflective. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/reflective.h b/linden/indra/llcommon/reflective.h index 10cecb0..6ed2b43 100644 --- a/linden/indra/llcommon/reflective.h +++ b/linden/indra/llcommon/reflective.h @@ -4,6 +4,8 @@ * @date 2006-05-15 * @brief Interface that must be implemented by all reflective classes. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_REFLECTIVE_H diff --git a/linden/indra/llcommon/reflectivet.h b/linden/indra/llcommon/reflectivet.h index e81d76a..85c7206 100644 --- a/linden/indra/llcommon/reflectivet.h +++ b/linden/indra/llcommon/reflectivet.h @@ -1,6 +1,8 @@ /** * @file reflectivet.h * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_REFLECTIVET_H diff --git a/linden/indra/llcommon/roles_constants.h b/linden/indra/llcommon/roles_constants.h index 3c885ab..54e6827 100644 --- a/linden/indra/llcommon/roles_constants.h +++ b/linden/indra/llcommon/roles_constants.h @@ -2,6 +2,8 @@ * @file roles_constants.h * @brief General Roles Constants * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_ROLES_CONSTANTS_H diff --git a/linden/indra/llcommon/stdenums.h b/linden/indra/llcommon/stdenums.h index b910570..92de405 100644 --- a/linden/indra/llcommon/stdenums.h +++ b/linden/indra/llcommon/stdenums.h @@ -2,6 +2,8 @@ * @file stdenums.h * @brief Enumerations for indra. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_STDENUMS_H diff --git a/linden/indra/llcommon/stdtypes.h b/linden/indra/llcommon/stdtypes.h index 118278f..f8982d7 100644 --- a/linden/indra/llcommon/stdtypes.h +++ b/linden/indra/llcommon/stdtypes.h @@ -2,6 +2,8 @@ * @file stdtypes.h * @brief Basic type declarations for cross platform compatibility. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,13 +26,11 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_STDTYPES_H #define LL_STDTYPES_H -#include -#include - typedef signed char S8; typedef unsigned char U8; typedef signed short S16; diff --git a/linden/indra/llcommon/string_table.h b/linden/indra/llcommon/string_table.h index 3d30c9f..f057007 100644 --- a/linden/indra/llcommon/string_table.h +++ b/linden/indra/llcommon/string_table.h @@ -2,6 +2,8 @@ * @file string_table.h * @brief Legacy wrapper header. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,5 +26,6 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llstringtable.h" diff --git a/linden/indra/llcommon/timer.h b/linden/indra/llcommon/timer.h index 3a098ec..ec3b62f 100644 --- a/linden/indra/llcommon/timer.h +++ b/linden/indra/llcommon/timer.h @@ -2,6 +2,8 @@ * @file timer.h * @brief Legacy wrapper header. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,5 +26,6 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "lltimer.h" diff --git a/linden/indra/llcommon/timing.cpp b/linden/indra/llcommon/timing.cpp index 0737beb..4115932 100644 --- a/linden/indra/llcommon/timing.cpp +++ b/linden/indra/llcommon/timing.cpp @@ -2,6 +2,8 @@ * @file timing.cpp * @brief This file will be deprecated in the future. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,4 +26,5 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ diff --git a/linden/indra/llcommon/timing.h b/linden/indra/llcommon/timing.h index b799001..3ea2a0e 100644 --- a/linden/indra/llcommon/timing.h +++ b/linden/indra/llcommon/timing.h @@ -2,6 +2,8 @@ * @file timing.h * @brief Cross-platform routines for doing timing. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,15 +26,15 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_TIMING_H #define LL_TIMING_H -#include #if LL_LINUX || LL_DARWIN || LL_SOLARIS -# include +#include #endif diff --git a/linden/indra/llcommon/u64.cpp b/linden/indra/llcommon/u64.cpp index 204c6c8..f2efef1 100644 --- a/linden/indra/llcommon/u64.cpp +++ b/linden/indra/llcommon/u64.cpp @@ -2,6 +2,8 @@ * @file u64.cpp * @brief Utilities to deal with U64s. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llcommon/u64.h b/linden/indra/llcommon/u64.h index da83e28..ad93ebf 100644 --- a/linden/indra/llcommon/u64.h +++ b/linden/indra/llcommon/u64.h @@ -2,6 +2,8 @@ * @file u64.h * @brief Utilities to deal with U64s. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_U64_H diff --git a/linden/indra/llimage/llimage.cpp b/linden/indra/llimage/llimage.cpp index fccd7b3..db19bd6 100644 --- a/linden/indra/llimage/llimage.cpp +++ b/linden/indra/llimage/llimage.cpp @@ -2,6 +2,8 @@ * @file llimage.cpp * @brief Base class for images. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,22 +26,17 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" -#include -#include -#include -#include -#include +#include "llimage.h" #include "llmath.h" -#include "stdtypes.h" #include "v4coloru.h" #include "llmemtype.h" -#include "llimage.h" #include "llimagebmp.h" #include "llimagetga.h" #include "llimagej2c.h" diff --git a/linden/indra/llimage/llimage.h b/linden/indra/llimage/llimage.h index e706c0a..65a7c54 100644 --- a/linden/indra/llimage/llimage.h +++ b/linden/indra/llimage/llimage.h @@ -2,6 +2,8 @@ * @file llimage.h * @brief Object for managing images and their textures. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,12 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLIMAGE_H #define LL_LLIMAGE_H -#include "stdtypes.h" #include "lluuid.h" #include "llstring.h" #include "llmemory.h" @@ -112,7 +114,7 @@ protected: public: static const LLString& getLastError() {return sLastErrorMessage;}; static void resetLastError() {sLastErrorMessage = LLString("No Error"); }; - static BOOL setLastError(const LLString& message, const LLString& filename = ""); // returns FALSE + static BOOL setLastError(const LLString& message, const LLString& filename = LLString()); // returns FALSE static void generateMip(const U8 *indata, U8* mipdata, int width, int height, S32 nchannels); diff --git a/linden/indra/llimage/llimagebmp.cpp b/linden/indra/llimage/llimagebmp.cpp index eaed63d..f842300 100644 --- a/linden/indra/llimage/llimagebmp.cpp +++ b/linden/indra/llimage/llimagebmp.cpp @@ -1,6 +1,8 @@ /** * @file llimagebmp.cpp * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llimage/llimagebmp.h b/linden/indra/llimage/llimagebmp.h index 556b4a2..2924ff4 100644 --- a/linden/indra/llimage/llimagebmp.h +++ b/linden/indra/llimage/llimagebmp.h @@ -2,6 +2,8 @@ * @file llimagebmp.h * @brief Image implementation for BMP. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLIMAGEBMP_H diff --git a/linden/indra/llimage/llimagedxt.cpp b/linden/indra/llimage/llimagedxt.cpp index 22d7557..6feece4 100644 --- a/linden/indra/llimage/llimagedxt.cpp +++ b/linden/indra/llimage/llimagedxt.cpp @@ -1,6 +1,8 @@ /** * @file llimagedxt.cpp * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llimage/llimagedxt.h b/linden/indra/llimage/llimagedxt.h index c52c866..23a5047 100644 --- a/linden/indra/llimage/llimagedxt.h +++ b/linden/indra/llimage/llimagedxt.h @@ -1,6 +1,8 @@ /** * @file llimagedxt.h * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLIMAGEDXT_H diff --git a/linden/indra/llimage/llimagej2c.cpp b/linden/indra/llimage/llimagej2c.cpp index 305b11d..0911c43 100644 --- a/linden/indra/llimage/llimagej2c.cpp +++ b/linden/indra/llimage/llimagej2c.cpp @@ -1,6 +1,8 @@ /** * @file llimagej2c.cpp * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -35,11 +38,13 @@ typedef LLImageJ2CImpl* (*CreateLLImageJ2CFunction)(); typedef void (*DestroyLLImageJ2CFunction)(LLImageJ2CImpl*); +typedef const char* (*EngineInfoLLImageJ2CFunction)(); //some "private static" variables so we only attempt to load //dynamic libaries once CreateLLImageJ2CFunction j2cimpl_create_func; DestroyLLImageJ2CFunction j2cimpl_destroy_func; +EngineInfoLLImageJ2CFunction j2cimpl_engineinfo_func; apr_pool_t *j2cimpl_dso_memory_pool; apr_dso_handle_t *j2cimpl_dso_handle; @@ -49,9 +54,10 @@ apr_dso_handle_t *j2cimpl_dso_handle; //function should ever be included LLImageJ2CImpl* fallbackCreateLLImageJ2CImpl(); void fallbackDestroyLLImageJ2CImpl(LLImageJ2CImpl* impl); +const char* fallbackEngineInfoLLImageJ2CImpl(); //static -//Loads the required "create" and "destroy" functions needed +//Loads the required "create", "destroy" and "engineinfo" functions needed void LLImageJ2C::openDSO() { //attempt to load a DSO and get some functions from it @@ -70,8 +76,8 @@ void LLImageJ2C::openDSO() #endif dso_path = gDirUtilp->findFile(dso_name, - gDirUtilp->getAppRODataDir(), - gDirUtilp->getExecutableDir()); + gDirUtilp->getAppRODataDir(), + gDirUtilp->getExecutableDir()); j2cimpl_dso_handle = NULL; j2cimpl_dso_memory_pool = NULL; @@ -89,6 +95,7 @@ void LLImageJ2C::openDSO() //now we want to load the functions we're interested in CreateLLImageJ2CFunction create_func = NULL; DestroyLLImageJ2CFunction dest_func = NULL; + EngineInfoLLImageJ2CFunction engineinfo_func = NULL; rv = apr_dso_sym((apr_dso_handle_sym_t*)&create_func, j2cimpl_dso_handle, @@ -100,13 +107,21 @@ void LLImageJ2C::openDSO() //so lets check for a destruction function rv = apr_dso_sym((apr_dso_handle_sym_t*)&dest_func, j2cimpl_dso_handle, - "destroyLLImageJ2CKDU"); + "destroyLLImageJ2CKDU"); if ( rv == APR_SUCCESS ) { - //k, everything is loaded alright - j2cimpl_create_func = create_func; - j2cimpl_destroy_func = dest_func; - all_functions_loaded = true; + //we've loaded the destroy function ok + rv = apr_dso_sym((apr_dso_handle_sym_t*)&engineinfo_func, + j2cimpl_dso_handle, + "engineInfoLLImageJ2CKDU"); + if ( rv == APR_SUCCESS ) + { + //ok, everything is loaded alright + j2cimpl_create_func = create_func; + j2cimpl_destroy_func = dest_func; + j2cimpl_engineinfo_func = engineinfo_func; + all_functions_loaded = true; + } } } } @@ -149,6 +164,15 @@ void LLImageJ2C::closeDSO() if (j2cimpl_dso_memory_pool) apr_pool_destroy(j2cimpl_dso_memory_pool); } +//static +std::string LLImageJ2C::getEngineInfo() +{ + if (!j2cimpl_engineinfo_func) + j2cimpl_engineinfo_func = fallbackEngineInfoLLImageJ2CImpl; + + return j2cimpl_engineinfo_func(); +} + LLImageJ2C::LLImageJ2C() : LLImageFormatted(IMG_CODEC_J2C), mMaxBytes(0), mRawDiscardLevel(-1), @@ -156,7 +180,7 @@ LLImageJ2C::LLImageJ2C() : LLImageFormatted(IMG_CODEC_J2C), mReversible(FALSE) { - //We assume here that if we wanted to destory via + //We assume here that if we wanted to create via //a dynamic library that the approriate open calls were made //before any calls to this constructor. @@ -175,7 +199,7 @@ LLImageJ2C::LLImageJ2C() : LLImageFormatted(IMG_CODEC_J2C), // virtual LLImageJ2C::~LLImageJ2C() { - //We assume here that if we wanted to destory via + //We assume here that if we wanted to destroy via //a dynamic library that the approriate open calls were made //before any calls to this destructor. diff --git a/linden/indra/llimage/llimagej2c.h b/linden/indra/llimage/llimagej2c.h index 00cb919..35b4d6b 100644 --- a/linden/indra/llimage/llimagej2c.h +++ b/linden/indra/llimage/llimagej2c.h @@ -2,6 +2,8 @@ * @file llimagej2c.h * @brief Image implmenation for jpeg2000. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLIMAGEJ2C_H @@ -68,6 +71,7 @@ public: static void openDSO(); static void closeDSO(); + static std::string getEngineInfo(); protected: friend class LLImageJ2CImpl; diff --git a/linden/indra/llimage/llimagejpeg.cpp b/linden/indra/llimage/llimagejpeg.cpp index 4ceecdf..f9b36bd 100644 --- a/linden/indra/llimage/llimagejpeg.cpp +++ b/linden/indra/llimage/llimagejpeg.cpp @@ -1,6 +1,8 @@ /** * @file llimagejpeg.cpp * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llimage/llimagejpeg.h b/linden/indra/llimage/llimagejpeg.h index 34b3f76..0be4002 100644 --- a/linden/indra/llimage/llimagejpeg.h +++ b/linden/indra/llimage/llimagejpeg.h @@ -2,6 +2,8 @@ * @file llimagejpeg.h * @brief This class compresses and decompresses JPEG files * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLIMAGEJPEG_H diff --git a/linden/indra/llimage/llimagepng.cpp b/linden/indra/llimage/llimagepng.cpp index d6b62a8..3e0414f 100644 --- a/linden/indra/llimage/llimagepng.cpp +++ b/linden/indra/llimage/llimagepng.cpp @@ -2,8 +2,9 @@ * @file llimagepng.cpp * @brief LLImageFormatted glue to encode / decode PNG files. * - * Copyright (c) 2007 Peekay Semyorka. - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -25,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llimage/llimagepng.h b/linden/indra/llimage/llimagepng.h index abdff7c..7a8e1f9 100644 --- a/linden/indra/llimage/llimagepng.h +++ b/linden/indra/llimage/llimagepng.h @@ -1,8 +1,9 @@ /* * @file llimagepng.h * - * Copyright (c) 2007 Peekay Semyorka. - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLIMAGEPNG_H diff --git a/linden/indra/llimage/llimagetga.cpp b/linden/indra/llimage/llimagetga.cpp index 39da50a..805297f 100644 --- a/linden/indra/llimage/llimagetga.cpp +++ b/linden/indra/llimage/llimagetga.cpp @@ -1,6 +1,8 @@ /** * @file llimagetga.cpp * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -747,6 +750,7 @@ BOOL LLImageTGA::decodeTruecolorRle32( LLImageRaw* raw_image, BOOL &alpha_opaque U32* dst_pixels = (U32*) dst; U8* src = getData() + mDataOffset; + U8* last_src = src + getDataSize(); U32 rgba; U8* rgba_byte_p = (U8*) &rgba; @@ -755,6 +759,10 @@ BOOL LLImageTGA::decodeTruecolorRle32( LLImageRaw* raw_image, BOOL &alpha_opaque while( dst_pixels <= last_dst_pixel ) { // Read RLE block header + + if (src >= last_src) + return FALSE; + U8 block_header_byte = *src; src++; @@ -762,6 +770,10 @@ BOOL LLImageTGA::decodeTruecolorRle32( LLImageRaw* raw_image, BOOL &alpha_opaque if( block_header_byte & 0x80 ) { // Encoded (duplicate-pixel) block + + if (src + 3 >= last_src) + return FALSE; + rgba_byte_p[0] = src[2]; rgba_byte_p[1] = src[1]; rgba_byte_p[2] = src[0]; @@ -786,6 +798,9 @@ BOOL LLImageTGA::decodeTruecolorRle32( LLImageRaw* raw_image, BOOL &alpha_opaque // Unencoded block do { + if (src + 3 >= last_src) + return FALSE; + ((U8*)dst_pixels)[0] = src[2]; ((U8*)dst_pixels)[1] = src[1]; ((U8*)dst_pixels)[2] = src[0]; @@ -813,10 +828,16 @@ BOOL LLImageTGA::decodeTruecolorRle15( LLImageRaw* raw_image ) U8* dst = raw_image->getData(); U8* src = getData() + mDataOffset; + U8* last_src = src + getDataSize(); U8* last_dst = dst + getComponents() * (getHeight() * getWidth() - 1); + while( dst <= last_dst ) { // Read RLE block header + + if (src >= last_src) + return FALSE; + U8 block_header_byte = *src; src++; @@ -826,6 +847,9 @@ BOOL LLImageTGA::decodeTruecolorRle15( LLImageRaw* raw_image ) // Encoded (duplicate-pixel) block do { + if (src + 2 >= last_src) + return FALSE; + decodeTruecolorPixel15( dst, src ); // slow dst += 3; block_pixel_count--; @@ -838,6 +862,9 @@ BOOL LLImageTGA::decodeTruecolorRle15( LLImageRaw* raw_image ) // Unencoded block do { + if (src + 2 >= last_src) + return FALSE; + decodeTruecolorPixel15( dst, src ); dst += 3; src += 2; @@ -859,10 +886,16 @@ BOOL LLImageTGA::decodeTruecolorRle24( LLImageRaw* raw_image ) U8* dst = raw_image->getData(); U8* src = getData() + mDataOffset; + U8* last_src = src + getDataSize(); U8* last_dst = dst + getComponents() * (getHeight() * getWidth() - 1); + while( dst <= last_dst ) { // Read RLE block header + + if (src >= last_src) + return FALSE; + U8 block_header_byte = *src; src++; @@ -872,6 +905,8 @@ BOOL LLImageTGA::decodeTruecolorRle24( LLImageRaw* raw_image ) // Encoded (duplicate-pixel) block do { + if (src + 2 >= last_src) + return FALSE; dst[0] = src[2]; dst[1] = src[1]; dst[2] = src[0]; @@ -886,6 +921,9 @@ BOOL LLImageTGA::decodeTruecolorRle24( LLImageRaw* raw_image ) // Unencoded block do { + if (src + 2 >= last_src) + return FALSE; + dst[0] = src[2]; dst[1] = src[1]; dst[2] = src[0]; @@ -908,16 +946,25 @@ BOOL LLImageTGA::decodeTruecolorRle8( LLImageRaw* raw_image ) U8* dst = raw_image->getData(); U8* src = getData() + mDataOffset; + U8* last_src = src + getDataSize(); U8* last_dst = dst + getHeight() * getWidth() - 1; + while( dst <= last_dst ) { // Read RLE block header + + if (src >= last_src) + return FALSE; + U8 block_header_byte = *src; src++; U8 block_pixel_count = (block_header_byte & 0x7F) + 1; if( block_header_byte & 0x80 ) { + if (src >= last_src) + return FALSE; + // Encoded (duplicate-pixel) block memset( dst, *src, block_pixel_count ); dst += block_pixel_count; @@ -928,6 +975,9 @@ BOOL LLImageTGA::decodeTruecolorRle8( LLImageRaw* raw_image ) // Unencoded block do { + if (src >= last_src) + return FALSE; + *dst = *src; dst++; src++; diff --git a/linden/indra/llimage/llimagetga.h b/linden/indra/llimage/llimagetga.h index d4d56d0..3bfe4e6 100644 --- a/linden/indra/llimage/llimagetga.h +++ b/linden/indra/llimage/llimagetga.h @@ -2,6 +2,8 @@ * @file llimagetga.h * @brief Image implementation to compresses and decompressed TGA files. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLIMAGETGA_H diff --git a/linden/indra/llimage/llimageworker.cpp b/linden/indra/llimage/llimageworker.cpp index 9affd59..61b15b2 100644 --- a/linden/indra/llimage/llimageworker.cpp +++ b/linden/indra/llimage/llimageworker.cpp @@ -2,6 +2,8 @@ * @file llimageworker.cpp * @brief Base class for images. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -99,10 +102,7 @@ bool LLImageWorker::doWork(S32 param) } else { - S32 nc = param ? 1 : mFormattedImage->getComponents(); - mDecodedImage = new LLImageRaw(mFormattedImage->getWidth(), - mFormattedImage->getHeight(), - nc); + mDecodedImage = new LLImageRaw(); // allow possibly smaller size set during decoding } } if (!decoded) diff --git a/linden/indra/llimage/llimageworker.h b/linden/indra/llimage/llimageworker.h index a84918d..f9c592f 100644 --- a/linden/indra/llimage/llimageworker.h +++ b/linden/indra/llimage/llimageworker.h @@ -2,6 +2,8 @@ * @file llimageworker.h * @brief Object for managing images and their textures. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLIMAGEWORKER_H diff --git a/linden/indra/llimage/llmapimagetype.h b/linden/indra/llimage/llmapimagetype.h index 690d3ec..b9d20d1 100644 --- a/linden/indra/llimage/llmapimagetype.h +++ b/linden/indra/llimage/llmapimagetype.h @@ -1,6 +1,8 @@ /** * @file llmapimagetype.h * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMAPIMAGETYPE_H diff --git a/linden/indra/llimage/llpngwrapper.cpp b/linden/indra/llimage/llpngwrapper.cpp index 52616d1..74a09b2 100644 --- a/linden/indra/llimage/llpngwrapper.cpp +++ b/linden/indra/llimage/llpngwrapper.cpp @@ -2,8 +2,9 @@ * @file llpngwrapper.cpp * @brief Encapsulates libpng read/write functionality. * - * Copyright (c) 2007 Peekay Semyorka. - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -25,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llimage/llpngwrapper.h b/linden/indra/llimage/llpngwrapper.h index 1b5b97f..1c66b8a 100644 --- a/linden/indra/llimage/llpngwrapper.h +++ b/linden/indra/llimage/llpngwrapper.h @@ -1,8 +1,9 @@ /* * @file llpngwrapper.h * - * Copyright (c) 2007 Peekay Semyorka. - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPNGWRAPPER_H diff --git a/linden/indra/llimagej2coj/llimagej2coj.cpp b/linden/indra/llimagej2coj/llimagej2coj.cpp index be6a087..7a323c8 100644 --- a/linden/indra/llimagej2coj/llimagej2coj.cpp +++ b/linden/indra/llimagej2coj/llimagej2coj.cpp @@ -2,6 +2,8 @@ * @file llimagej2coj.cpp * @brief This is an implementation of JPEG2000 encode/decode using OpenJPEG. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,18 +26,24 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" #include "llimagej2coj.h" // this is defined so that we get static linking. -#define OPJ_STATIC #include "openjpeg/openjpeg.h" #include "lltimer.h" #include "llmemory.h" +const char* fallbackEngineInfoLLImageJ2CImpl() +{ + return (std::string("OpenJPEG: " OPENJPEG_VERSION ", Runtime: ") + + opj_version()).c_str(); +} + LLImageJ2CImpl* fallbackCreateLLImageJ2CImpl() { return new LLImageJ2COJ(); diff --git a/linden/indra/llimagej2coj/llimagej2coj.h b/linden/indra/llimagej2coj/llimagej2coj.h index e896b0a..2922c4a 100644 --- a/linden/indra/llimagej2coj/llimagej2coj.h +++ b/linden/indra/llimagej2coj/llimagej2coj.h @@ -2,6 +2,8 @@ * @file llimagej2coj.h * @brief This is an implementation of JPEG2000 encode/decode using OpenJPEG. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLIMAGEJ2COJ_H diff --git a/linden/indra/llinventory/llcategory.cpp b/linden/indra/llinventory/llcategory.cpp index 93f86f9..2341999 100644 --- a/linden/indra/llinventory/llcategory.cpp +++ b/linden/indra/llinventory/llcategory.cpp @@ -1,6 +1,8 @@ /** * @file llcategory.cpp * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llinventory/llcategory.h b/linden/indra/llinventory/llcategory.h index ed28a7f..c7c4067 100644 --- a/linden/indra/llinventory/llcategory.h +++ b/linden/indra/llinventory/llcategory.h @@ -2,6 +2,8 @@ * @file llcategory.h * @brief LLCategory class header file. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCATEGORY_H diff --git a/linden/indra/llinventory/lleconomy.cpp b/linden/indra/llinventory/lleconomy.cpp index e3e909b..24e9bf1 100644 --- a/linden/indra/llinventory/lleconomy.cpp +++ b/linden/indra/llinventory/lleconomy.cpp @@ -1,6 +1,8 @@ /** * @file lleconomy.cpp * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llinventory/lleconomy.h b/linden/indra/llinventory/lleconomy.h index acda67e..d1e1adc 100644 --- a/linden/indra/llinventory/lleconomy.h +++ b/linden/indra/llinventory/lleconomy.h @@ -1,6 +1,8 @@ /** * @file lleconomy.h * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLECONOMY_H diff --git a/linden/indra/llinventory/llinventory.cpp b/linden/indra/llinventory/llinventory.cpp index 3800de2..4d411e6 100644 --- a/linden/indra/llinventory/llinventory.cpp +++ b/linden/indra/llinventory/llinventory.cpp @@ -2,6 +2,8 @@ * @file llinventory.cpp * @brief Implementation of the inventory system. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,12 +26,11 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" -#include - #include "llinventory.h" #include "lldbstrings.h" diff --git a/linden/indra/llinventory/llinventory.h b/linden/indra/llinventory/llinventory.h index b24fe79..065c82d 100644 --- a/linden/indra/llinventory/llinventory.h +++ b/linden/indra/llinventory/llinventory.h @@ -2,6 +2,8 @@ * @file llinventory.h * @brief LLInventoryItem and LLInventoryCategory class declaration. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLINVENTORY_H diff --git a/linden/indra/llinventory/llinventorytype.cpp b/linden/indra/llinventory/llinventorytype.cpp index 96dfb5e..ac16cea 100644 --- a/linden/indra/llinventory/llinventorytype.cpp +++ b/linden/indra/llinventory/llinventorytype.cpp @@ -2,6 +2,8 @@ * @file llinventorytype.cpp * @brief Inventory item type, more specific than an asset type. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llinventory/llinventorytype.h b/linden/indra/llinventory/llinventorytype.h index 7d34c87..dcc2502 100644 --- a/linden/indra/llinventory/llinventorytype.h +++ b/linden/indra/llinventory/llinventorytype.h @@ -2,6 +2,8 @@ * @file llinventorytype.h * @brief Inventory item type, more specific than an asset type. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLINVENTORYTYPE_H diff --git a/linden/indra/llinventory/lllandmark.cpp b/linden/indra/llinventory/lllandmark.cpp index ae7a991..cac41c3 100644 --- a/linden/indra/llinventory/lllandmark.cpp +++ b/linden/indra/llinventory/lllandmark.cpp @@ -2,6 +2,8 @@ * @file lllandmark.cpp * @brief Landmark asset class * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,15 +26,13 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" #include "lllandmark.h" -#include -#include #include -#include // for sscanf() on linux #include "message.h" #include "llregionhandle.h" diff --git a/linden/indra/llinventory/lllandmark.h b/linden/indra/llinventory/lllandmark.h index 69c377a..fbcd950 100644 --- a/linden/indra/llinventory/lllandmark.h +++ b/linden/indra/llinventory/lllandmark.h @@ -2,6 +2,8 @@ * @file lllandmark.h * @brief Landmark asset class * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ diff --git a/linden/indra/llinventory/llnotecard.cpp b/linden/indra/llinventory/llnotecard.cpp index 86eb5b2..733a567 100644 --- a/linden/indra/llinventory/llnotecard.cpp +++ b/linden/indra/llinventory/llnotecard.cpp @@ -2,6 +2,8 @@ * @file llnotecard.cpp * @brief LLNotecard class definition * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llinventory/llnotecard.h b/linden/indra/llinventory/llnotecard.h index 3d89c7a..369bf78 100644 --- a/linden/indra/llinventory/llnotecard.h +++ b/linden/indra/llinventory/llnotecard.h @@ -2,6 +2,8 @@ * @file llnotecard.h * @brief LLNotecard class declaration * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_NOTECARD_H diff --git a/linden/indra/llinventory/llparcel.cpp b/linden/indra/llinventory/llparcel.cpp index 5902acd..3a67385 100644 --- a/linden/indra/llinventory/llparcel.cpp +++ b/linden/indra/llinventory/llparcel.cpp @@ -2,6 +2,8 @@ * @file llparcel.cpp * @brief A land parcel. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -256,42 +259,25 @@ void LLParcel::overrideParcelFlags(U32 flags) mParcelFlags = flags; } -void set_std_string(const char* src, std::string& dest) -{ - if(src) - { - dest.assign(src); - } - else - { -#if (LL_LINUX && __GNUC__ < 3) - dest.assign(std::string("")); -#else - dest.clear(); -#endif - } -} - -void LLParcel::setName(const char* name) +void LLParcel::setName(const LLString& name) { // The escaping here must match the escaping in the database // abstraction layer. - set_std_string(name, mName); + mName = name; LLStringFn::replace_nonprintable(mName, LL_UNKNOWN_CHAR); } -void LLParcel::setDesc(const char* desc) +void LLParcel::setDesc(const LLString& desc) { // The escaping here must match the escaping in the database // abstraction layer. - set_std_string(desc, mDesc); + mDesc = desc; mDesc = rawstr_to_utf8(mDesc); } -void LLParcel::setMusicURL(const char* url) +void LLParcel::setMusicURL(const LLString& url) { - set_std_string(url, mMusicURL); - + mMusicURL = url; // The escaping here must match the escaping in the database // abstraction layer. // This should really filter the url in some way. Other than @@ -299,10 +285,9 @@ void LLParcel::setMusicURL(const char* url) LLStringFn::replace_nonprintable(mMusicURL, LL_UNKNOWN_CHAR); } -void LLParcel::setMediaURL(const char* url) +void LLParcel::setMediaURL(const LLString& url) { - set_std_string(url, mMediaURL); - + mMediaURL = url; // The escaping here must match the escaping in the database // abstraction layer if it's ever added. // This should really filter the url in some way. Other than @@ -568,19 +553,19 @@ BOOL LLParcel::importStream(std::istream& input_stream) } else if ("name" == keyword) { - setName( value.c_str() ); + setName( value ); } else if ("desc" == keyword) { - setDesc( value.c_str() ); + setDesc( value ); } else if ("music_url" == keyword) { - setMusicURL( value.c_str() ); + setMusicURL( value ); } else if ("media_url" == keyword) { - setMediaURL( value.c_str() ); + setMediaURL( value ); } else if ("media_id" == keyword) { @@ -1835,3 +1820,4 @@ LLParcel::ECategory category_ui_string_to_category(const char* s) return LLParcel::C_ANY; } + diff --git a/linden/indra/llinventory/llparcel.h b/linden/indra/llinventory/llparcel.h index 66af8ad..9c63008 100644 --- a/linden/indra/llinventory/llparcel.h +++ b/linden/indra/llinventory/llparcel.h @@ -1,6 +1,8 @@ /** * @file llparcel.h * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,15 +25,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPARCEL_H #define LL_LLPARCEL_H -#include -#include - -#include "lldarray.h" #include "lluuid.h" #include "llparcelflags.h" #include "llpermissions.h" @@ -204,10 +203,10 @@ public: // MANIPULATORS void generateNewID() { mID.generate(); } - void setName(const char* name); - void setDesc(const char* desc); - void setMusicURL(const char* url); - void setMediaURL(const char* url); + void setName(const LLString& name); + void setDesc(const LLString& desc); + void setMusicURL(const LLString& url); + void setMediaURL(const LLString& url); void setMediaID(const LLUUID& id) { mMediaID = id; } void setMediaAutoScale ( U8 flagIn ) { mMediaAutoScale = flagIn; } virtual void setLocalID(S32 local_id); @@ -257,7 +256,7 @@ public: void setDrawDistance(F32 dist) { mDrawDistance = dist; } void setSalePrice(S32 price) { mSalePrice = price; } void setGroupID(const LLUUID& id) { mGroupID = id; } - //void setGroupName(const char* s) { mGroupName.assign(s); } + //void setGroupName(const LLString& s) { mGroupName.assign(s); } void setPassPrice(S32 price) { mPassPrice = price; } void setPassHours(F32 hours) { mPassHours = hours; } @@ -293,10 +292,10 @@ public: // ACCESSORS const LLUUID& getID() const { return mID; } - const char* getName() const { return mName.c_str(); } - const char* getDesc() const { return mDesc.c_str(); } - const char* getMusicURL() const { return mMusicURL.c_str(); } - const char* getMediaURL() const { return mMediaURL.c_str(); } + const LLString& getName() const { return mName; } + const LLString& getDesc() const { return mDesc; } + const LLString& getMusicURL() const { return mMusicURL; } + const LLString& getMediaURL() const { return mMediaURL; } const LLUUID& getMediaID() const { return mMediaID; } U8 getMediaAutoScale() const { return mMediaAutoScale; } S32 getLocalID() const { return mLocalID; } @@ -568,10 +567,10 @@ protected: F32 mDrawDistance; U32 mParcelFlags; S32 mSalePrice; // linden dollars - std::string mName; - std::string mDesc; - std::string mMusicURL; - std::string mMediaURL; + LLString mName; + LLString mDesc; + LLString mMusicURL; + LLString mMediaURL; U8 mMediaAutoScale; LLUUID mMediaID; S32 mPassPrice; diff --git a/linden/indra/llinventory/llparcelflags.h b/linden/indra/llinventory/llparcelflags.h index 0c07b29..d691d4d 100644 --- a/linden/indra/llinventory/llparcelflags.h +++ b/linden/indra/llinventory/llparcelflags.h @@ -1,6 +1,8 @@ /** * @file llparcelflags.h * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPARCEL_FLAGS_H diff --git a/linden/indra/llinventory/llpermissions.cpp b/linden/indra/llinventory/llpermissions.cpp index 925b68f..8f9f73d 100644 --- a/linden/indra/llinventory/llpermissions.cpp +++ b/linden/indra/llinventory/llpermissions.cpp @@ -3,6 +3,8 @@ * @author Phoenix * @brief Permissions for objects and inventory. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -1140,6 +1143,12 @@ void mask_to_string(U32 mask, char* str) *str = '\0'; } +std::string mask_to_string(U32 mask) +{ + char str[16]; + mask_to_string(mask, str); + return std::string(str); +} ///---------------------------------------------------------------------------- /// exported functions diff --git a/linden/indra/llinventory/llpermissions.h b/linden/indra/llinventory/llpermissions.h index 9607a9b..9370d64 100644 --- a/linden/indra/llinventory/llpermissions.h +++ b/linden/indra/llinventory/llpermissions.h @@ -2,6 +2,8 @@ * @file llpermissions.h * @brief Permissions structures for objects. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,14 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPERMISSIONS_H #define LL_LLPERMISSIONS_H -#include -#include - #include "llpermissionsflags.h" #include "llsd.h" #include "lluuid.h" @@ -41,6 +41,7 @@ // prototypes class LLMessageSystem; extern void mask_to_string(U32 mask, char* str); +extern std::string mask_to_string(U32 mask); template class LLMetaClassT; //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ diff --git a/linden/indra/llinventory/llpermissionsflags.h b/linden/indra/llinventory/llpermissionsflags.h index 72778be..87f57e2 100644 --- a/linden/indra/llinventory/llpermissionsflags.h +++ b/linden/indra/llinventory/llpermissionsflags.h @@ -1,6 +1,8 @@ /** * @file llpermissionsflags.h * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPERMISSIONSFLAGS_H diff --git a/linden/indra/llinventory/llsaleinfo.cpp b/linden/indra/llinventory/llsaleinfo.cpp index 0258259..d0c7c72 100644 --- a/linden/indra/llinventory/llsaleinfo.cpp +++ b/linden/indra/llinventory/llsaleinfo.cpp @@ -2,6 +2,8 @@ * @file llsaleinfo.cpp * @brief * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include diff --git a/linden/indra/llinventory/llsaleinfo.h b/linden/indra/llinventory/llsaleinfo.h index fd6429e..e22466b 100644 --- a/linden/indra/llinventory/llsaleinfo.h +++ b/linden/indra/llinventory/llsaleinfo.h @@ -2,6 +2,8 @@ * @file llsaleinfo.h * @brief LLSaleInfo class header file. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,14 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSALEINFO_H #define LL_LLSALEINFO_H -#include -#include - #include "llpermissionsflags.h" #include "llsd.h" #include "llxmlnode.h" diff --git a/linden/indra/llinventory/lltransactionflags.cpp b/linden/indra/llinventory/lltransactionflags.cpp index ffd3271..d4c97d1 100644 --- a/linden/indra/llinventory/lltransactionflags.cpp +++ b/linden/indra/llinventory/lltransactionflags.cpp @@ -3,6 +3,8 @@ * @brief Some exported symbols and functions for dealing with * transaction flags. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,11 +27,14 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" #include "lltransactionflags.h" +#include "lltransactiontypes.h" +#include "lluuid.h" const U8 TRANSACTION_FLAGS_NONE = 0; const U8 TRANSACTION_FLAG_SOURCE_GROUP = 1; @@ -61,3 +66,85 @@ BOOL is_tf_owner_group(TransactionFlags flags) return ((flags & TRANSACTION_FLAG_OWNER_GROUP) == TRANSACTION_FLAG_OWNER_GROUP); } +void append_reason( + std::ostream& ostr, + S32 transaction_type, + const char* description) +{ + switch( transaction_type ) + { + case TRANS_OBJECT_SALE: + ostr << " for " << (description ? description : ""); + break; + case TRANS_LAND_SALE: + ostr << " for a parcel of land"; + break; + case TRANS_LAND_PASS_SALE: + ostr << " for a land access pass"; + break; + case TRANS_GROUP_LAND_DEED: + ostr << " for deeding land"; + default: + break; + } +} + +std::string build_transfer_message_to_source( + S32 amount, + const LLUUID& source_id, + const LLUUID& dest_id, + const std::string& dest_name, + S32 transaction_type, + const char* description) +{ + lldebugs << "build_transfer_message_to_source: " << amount << " " + << source_id << " " << dest_id << " " << dest_name << " " + << (description?description:"(no desc)") << llendl; + if((0 == amount) || source_id.isNull()) return ll_safe_string(description); + std::ostringstream ostr; + if(dest_id.isNull()) + { + ostr << "You paid L$" << amount; + switch(transaction_type) + { + case TRANS_GROUP_CREATE: + ostr << " to create a group"; + break; + case TRANS_GROUP_JOIN: + ostr << " to join a group"; + break; + case TRANS_UPLOAD_CHARGE: + ostr << " to upload"; + break; + default: + break; + } + } + else + { + ostr << "You paid " << dest_name << " L$" << amount; + append_reason(ostr, transaction_type, description); + } + ostr << "."; + return ostr.str(); +} + +std::string build_transfer_message_to_destination( + S32 amount, + const LLUUID& dest_id, + const LLUUID& source_id, + const std::string& source_name, + S32 transaction_type, + const char* description) +{ + lldebugs << "build_transfer_message_to_dest: " << amount << " " + << dest_id << " " << source_id << " " << source_name << " " + << (description?description:"(no desc)") << llendl; + if(0 == amount) return std::string(); + if(dest_id.isNull()) return ll_safe_string(description); + std::ostringstream ostr; + ostr << source_name << " paid you L$" << amount; + append_reason(ostr, transaction_type, description); + ostr << "."; + return ostr.str(); +} diff --git a/linden/indra/llinventory/lltransactionflags.h b/linden/indra/llinventory/lltransactionflags.h index 3675074..f5ee9d6 100644 --- a/linden/indra/llinventory/lltransactionflags.h +++ b/linden/indra/llinventory/lltransactionflags.h @@ -1,6 +1,8 @@ /** * @file lltransactionflags.h * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTRANSACTIONFLAGS_H @@ -44,4 +47,22 @@ BOOL is_tf_source_group(TransactionFlags flags); BOOL is_tf_dest_group(TransactionFlags flags); BOOL is_tf_owner_group(TransactionFlags flags); +// stupid helper functions which should be replaced with some kind of +// internationalizeable message. +std::string build_transfer_message_to_source( + S32 amount, + const LLUUID& source_id, + const LLUUID& dest_id, + const std::string& dest_name, + S32 transaction_type, + const char* description); + +std::string build_transfer_message_to_destination( + S32 amount, + const LLUUID& dest_id, + const LLUUID& source_id, + const std::string& source_name, + S32 transaction_type, + const char* description); + #endif // LL_LLTRANSACTIONFLAGS_H diff --git a/linden/indra/llinventory/lltransactiontypes.h b/linden/indra/llinventory/lltransactiontypes.h index 6eaced9..8140370 100644 --- a/linden/indra/llinventory/lltransactiontypes.h +++ b/linden/indra/llinventory/lltransactiontypes.h @@ -1,6 +1,8 @@ /** * @file lltransactiontypes.h * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTRANSACTIONTYPES_H diff --git a/linden/indra/llinventory/lluserrelations.cpp b/linden/indra/llinventory/lluserrelations.cpp index 5f01e51..0f1b48e 100644 --- a/linden/indra/llinventory/lluserrelations.cpp +++ b/linden/indra/llinventory/lluserrelations.cpp @@ -4,6 +4,8 @@ * @date 2006-10-12 * @brief Implementation of a simple cache of user relations. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llinventory/lluserrelations.h b/linden/indra/llinventory/lluserrelations.h index 69f5966..4483013 100644 --- a/linden/indra/llinventory/lluserrelations.h +++ b/linden/indra/llinventory/lluserrelations.h @@ -4,6 +4,8 @@ * @date 2006-10-12 * @brief Declaration of a class for handling granted rights. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLUSERRELAIONS_H diff --git a/linden/indra/llmath/camera.h b/linden/indra/llmath/camera.h index be8c711..d41af4b 100644 --- a/linden/indra/llmath/camera.h +++ b/linden/indra/llmath/camera.h @@ -2,6 +2,8 @@ * @file camera.h * @brief Legacy wrapper header. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llcamera.h" diff --git a/linden/indra/llmath/coordframe.h b/linden/indra/llmath/coordframe.h index 01d3031..384167a 100644 --- a/linden/indra/llmath/coordframe.h +++ b/linden/indra/llmath/coordframe.h @@ -2,6 +2,8 @@ * @file coordframe.h * @brief Legacy wrapper header. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llcoordframe.h" diff --git a/linden/indra/llmath/llbboxlocal.cpp b/linden/indra/llmath/llbboxlocal.cpp index 505c7e6..313013e 100644 --- a/linden/indra/llmath/llbboxlocal.cpp +++ b/linden/indra/llmath/llbboxlocal.cpp @@ -2,6 +2,8 @@ * @file llbboxlocal.cpp * @brief General purpose bounding box class (Not axis aligned). * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmath/llbboxlocal.h b/linden/indra/llmath/llbboxlocal.h index 4fdc01f..043f2df 100644 --- a/linden/indra/llmath/llbboxlocal.h +++ b/linden/indra/llmath/llbboxlocal.h @@ -2,6 +2,8 @@ * @file llbboxlocal.h * @brief General purpose bounding box class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_BBOXLOCAL_H diff --git a/linden/indra/llmath/llcamera.cpp b/linden/indra/llmath/llcamera.cpp index c32bb67..2ec9ba8 100644 --- a/linden/indra/llmath/llcamera.cpp +++ b/linden/indra/llmath/llcamera.cpp @@ -2,6 +2,8 @@ * @file llcamera.cpp * @brief Implementation of the LLCamera class. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmath/llcamera.h b/linden/indra/llmath/llcamera.h index b5f78f4..67ffb2e 100644 --- a/linden/indra/llmath/llcamera.h +++ b/linden/indra/llmath/llcamera.h @@ -2,6 +2,8 @@ * @file llcamera.h * @brief Header file for the LLCamera class. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_CAMERA_H diff --git a/linden/indra/llmath/llcoord.h b/linden/indra/llmath/llcoord.h index a1ed130..91fd507 100644 --- a/linden/indra/llmath/llcoord.h +++ b/linden/indra/llmath/llcoord.h @@ -1,6 +1,8 @@ /** * @file llcoord.h * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCOORD_H diff --git a/linden/indra/llmath/llcoordframe.cpp b/linden/indra/llmath/llcoordframe.cpp index 1650dd2..70d4646 100644 --- a/linden/indra/llmath/llcoordframe.cpp +++ b/linden/indra/llmath/llcoordframe.cpp @@ -2,6 +2,8 @@ * @file llcoordframe.cpp * @brief LLCoordFrame class implementation. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -60,7 +63,8 @@ LLCoordFrame::LLCoordFrame(const LLVector3 &origin) : { if( !mOrigin.isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::LLCoordFrame()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::LLCoordFrame()" << llendl; } } @@ -71,7 +75,8 @@ LLCoordFrame::LLCoordFrame(const LLVector3 &origin, const LLVector3 &direction) if( !isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::LLCoordFrame()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::LLCoordFrame()" << llendl; } } @@ -85,7 +90,8 @@ LLCoordFrame::LLCoordFrame(const LLVector3 &x_axis, { if( !isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::LLCoordFrame()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::LLCoordFrame()" << llendl; } } @@ -100,7 +106,8 @@ LLCoordFrame::LLCoordFrame(const LLVector3 &origin, { if( !isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::LLCoordFrame()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::LLCoordFrame()" << llendl; } } @@ -114,7 +121,8 @@ LLCoordFrame::LLCoordFrame(const LLVector3 &origin, { if( !isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::LLCoordFrame()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::LLCoordFrame()" << llendl; } } @@ -128,7 +136,8 @@ LLCoordFrame::LLCoordFrame(const LLQuaternion &q) : if( !isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::LLCoordFrame()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::LLCoordFrame()" << llendl; } } @@ -142,7 +151,8 @@ LLCoordFrame::LLCoordFrame(const LLVector3 &origin, const LLQuaternion &q) : if( !isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::LLCoordFrame()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::LLCoordFrame()" << llendl; } } @@ -154,7 +164,8 @@ LLCoordFrame::LLCoordFrame(const LLMatrix4 &mat) : { if( !isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::LLCoordFrame()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::LLCoordFrame()" << llendl; } } @@ -169,7 +180,8 @@ LLCoordFrame::LLCoordFrame(const F32 *origin, const F32 *rotation) : { if( !isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::LLCoordFrame()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::LLCoordFrame()" << llendl; } } */ @@ -183,7 +195,8 @@ LLCoordFrame::LLCoordFrame(const F32 *origin_and_rotation) : { if( !isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::LLCoordFrame()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::LLCoordFrame()" << llendl; } } */ @@ -211,7 +224,8 @@ void LLCoordFrame::setOrigin(F32 x, F32 y, F32 z) if( !mOrigin.isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::setOrigin()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::setOrigin()" << llendl; } } @@ -220,7 +234,8 @@ void LLCoordFrame::setOrigin(const LLVector3 &new_origin) mOrigin = new_origin; if( !mOrigin.isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::setOrigin()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::setOrigin()" << llendl; } } @@ -232,7 +247,8 @@ void LLCoordFrame::setOrigin(const F32 *origin) if( !mOrigin.isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::setOrigin()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::setOrigin()" << llendl; } } @@ -242,7 +258,8 @@ void LLCoordFrame::setOrigin(const LLCoordFrame &frame) if( !mOrigin.isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::setOrigin()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::setOrigin()" << llendl; } } @@ -258,7 +275,8 @@ void LLCoordFrame::setAxes(const LLVector3 &x_axis, mZAxis = z_axis; if( !isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::setAxes()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::setAxes()" << llendl; } } @@ -270,7 +288,8 @@ void LLCoordFrame::setAxes(const LLMatrix3 &rotation_matrix) mZAxis.setVec(rotation_matrix.mMatrix[VZ]); if( !isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::setAxes()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::setAxes()" << llendl; } } @@ -281,7 +300,8 @@ void LLCoordFrame::setAxes(const LLQuaternion &q ) setAxes(rotation_matrix); if( !isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::setAxes()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::setAxes()" << llendl; } } @@ -300,7 +320,8 @@ void LLCoordFrame::setAxes( const F32 *rotation_matrix ) if( !isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::setAxes()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::setAxes()" << llendl; } } @@ -313,7 +334,8 @@ void LLCoordFrame::setAxes(const LLCoordFrame &frame) if( !isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::setAxes()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::setAxes()" << llendl; } } @@ -328,7 +350,8 @@ void LLCoordFrame::translate(F32 x, F32 y, F32 z) if( !mOrigin.isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::translate()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::translate()" << llendl; } } @@ -339,7 +362,8 @@ void LLCoordFrame::translate(const LLVector3 &v) if( !mOrigin.isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::translate()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::translate()" << llendl; } } @@ -352,7 +376,8 @@ void LLCoordFrame::translate(const F32 *origin) if( !mOrigin.isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::translate()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::translate()" << llendl; } } @@ -388,7 +413,8 @@ void LLCoordFrame::rotate(const LLMatrix3 &rotation_matrix) if( !isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::rotate()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::rotate()" << llendl; } } @@ -401,7 +427,8 @@ void LLCoordFrame::roll(F32 angle) if( !mYAxis.isFinite() || !mZAxis.isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::roll()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::roll()" << llendl; } } @@ -413,7 +440,8 @@ void LLCoordFrame::pitch(F32 angle) if( !mXAxis.isFinite() || !mZAxis.isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::pitch()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::pitch()" << llendl; } } @@ -425,7 +453,8 @@ void LLCoordFrame::yaw(F32 angle) if( !mXAxis.isFinite() || !mYAxis.isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::yaw()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::yaw()" << llendl; } } @@ -484,7 +513,8 @@ size_t LLCoordFrame::readOrientation(const char *buffer) if( !isFinite() ) { - llerrs << "Non Finite in LLCoordFrame::readOrientation()" << llendl; + reset(); + llwarns << "Non Finite in LLCoordFrame::readOrientation()" << llendl; } return 12*sizeof(F32); diff --git a/linden/indra/llmath/llcoordframe.h b/linden/indra/llmath/llcoordframe.h index 2777cbe..95deba6 100644 --- a/linden/indra/llmath/llcoordframe.h +++ b/linden/indra/llmath/llcoordframe.h @@ -2,6 +2,8 @@ * @file llcoordframe.h * @brief LLCoordFrame class header file. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_COORDFRAME_H diff --git a/linden/indra/llmath/llcrc.cpp b/linden/indra/llmath/llcrc.cpp index 5b3ab4b..0836ccb 100644 --- a/linden/indra/llmath/llcrc.cpp +++ b/linden/indra/llmath/llcrc.cpp @@ -2,6 +2,8 @@ * @file llcrc.cpp * @brief implementation of the crc class. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -31,8 +34,6 @@ #include "llcrc.h" #include "llerror.h" -#include - /* Copyright (C) 1986 Gary S. Brown. You may use this program, or code or tables extracted from it, as desired without restriction.*/ diff --git a/linden/indra/llmath/llcrc.h b/linden/indra/llmath/llcrc.h index 9f71fcc..287c1fb 100644 --- a/linden/indra/llmath/llcrc.h +++ b/linden/indra/llmath/llcrc.h @@ -2,6 +2,8 @@ * @file llcrc.h * @brief LLCRC class header file. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCRC_H diff --git a/linden/indra/llmath/llinterp.h b/linden/indra/llmath/llinterp.h index 724fb31..0ad9113 100644 --- a/linden/indra/llmath/llinterp.h +++ b/linden/indra/llmath/llinterp.h @@ -1,6 +1,8 @@ /** * @file llinterp.h * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLINTERP_H diff --git a/linden/indra/llmath/llmath.h b/linden/indra/llmath/llmath.h index 9be2524..f1b223f 100644 --- a/linden/indra/llmath/llmath.h +++ b/linden/indra/llmath/llmath.h @@ -2,6 +2,8 @@ * @file llmath.h * @brief Useful math constants and macros. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,17 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLMATH_H #define LLMATH_H -#include -#include -#include - -#include "lldefs.h" - // work around for Windows & older gcc non-standard function names. #if LL_WINDOWS #define llisnan(val) _isnan(val) diff --git a/linden/indra/llmath/llmd5.cpp b/linden/indra/llmath/llmd5.cpp index 1a8630c..033eb2f 100644 --- a/linden/indra/llmath/llmd5.cpp +++ b/linden/indra/llmath/llmd5.cpp @@ -1,6 +1,8 @@ /** * @file llmd5.cpp * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // llMD5.CC - source code for the C++/object oriented translation and @@ -78,10 +81,7 @@ documentation and/or software. #include "llmd5.h" -#include -#include -#include -#include +#include // how many bytes to grab at a time when checking files const int LLMD5::BLOCK_LEN = 4096; diff --git a/linden/indra/llmath/llmd5.h b/linden/indra/llmath/llmd5.h index 5df98bf..7dabbfe 100644 --- a/linden/indra/llmath/llmd5.h +++ b/linden/indra/llmath/llmd5.h @@ -1,6 +1,8 @@ /** * @file llmd5.h * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMD5_H @@ -69,9 +72,6 @@ documentation and/or software. */ -#include -#include - // use for the raw digest output const int MD5RAW_BYTES = 16; diff --git a/linden/indra/llmath/lloctree.h b/linden/indra/llmath/lloctree.h index 2395f0f..def6cb4 100644 --- a/linden/indra/llmath/lloctree.h +++ b/linden/indra/llmath/lloctree.h @@ -2,6 +2,8 @@ * @file lloctree.h * @brief Octree declaration. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLOCTREE_H diff --git a/linden/indra/llmath/llperlin.cpp b/linden/indra/llmath/llperlin.cpp index 38b4d0d..4dcc7ab 100644 --- a/linden/indra/llmath/llperlin.cpp +++ b/linden/indra/llmath/llperlin.cpp @@ -1,6 +1,8 @@ /** * @file llperlin.cpp * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmath/llperlin.h b/linden/indra/llmath/llperlin.h index e5fc4b0..63daaa6 100644 --- a/linden/indra/llmath/llperlin.h +++ b/linden/indra/llmath/llperlin.h @@ -1,6 +1,8 @@ /** * @file llperlin.h * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_PERLIN_H diff --git a/linden/indra/llmath/llplane.h b/linden/indra/llmath/llplane.h index 0e0e17d..c1fb7d8 100644 --- a/linden/indra/llmath/llplane.h +++ b/linden/indra/llmath/llplane.h @@ -1,6 +1,8 @@ /** * @file llplane.h * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPLANE_H diff --git a/linden/indra/llmath/llquantize.h b/linden/indra/llmath/llquantize.h index a4fd67a..817c4c3 100644 --- a/linden/indra/llmath/llquantize.h +++ b/linden/indra/llmath/llquantize.h @@ -3,6 +3,8 @@ * @brief useful routines for quantizing floats to various length ints * and back out again * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLQUANTIZE_H @@ -40,6 +43,18 @@ const U8 FIRSTVALIDCHAR = 54; const U8 MAXSTRINGVAL = U8MAX - FIRSTVALIDCHAR; //we don't allow newline or null +inline U16 F32_to_U16_ROUND(F32 val, F32 lower, F32 upper) +{ + val = llclamp(val, lower, upper); + // make sure that the value is positive and normalized to <0, 1> + val -= lower; + val /= (upper - lower); + + // round the value. Sreturn the U16 + return (U16)(llround(val*U16MAX)); +} + + inline U16 F32_to_U16(F32 val, F32 lower, F32 upper) { val = llclamp(val, lower, upper); @@ -67,6 +82,19 @@ inline F32 U16_to_F32(U16 ival, F32 lower, F32 upper) return val; } + +inline U8 F32_to_U8_ROUND(F32 val, F32 lower, F32 upper) +{ + val = llclamp(val, lower, upper); + // make sure that the value is positive and normalized to <0, 1> + val -= lower; + val /= (upper - lower); + + // return the rounded U8 + return (U8)(llround(val*U8MAX)); +} + + inline U8 F32_to_U8(F32 val, F32 lower, F32 upper) { val = llclamp(val, lower, upper); diff --git a/linden/indra/llmath/llquaternion.cpp b/linden/indra/llmath/llquaternion.cpp index 06e34af..34c1fd1 100644 --- a/linden/indra/llmath/llquaternion.cpp +++ b/linden/indra/llmath/llquaternion.cpp @@ -2,6 +2,8 @@ * @file llquaternion.cpp * @brief LLQuaternion class implementation. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -107,23 +110,27 @@ void LLQuaternion::quantize16(F32 lower, F32 upper) F32 z = mQ[VZ]; F32 s = mQ[VS]; - x = U16_to_F32(F32_to_U16(x, lower, upper), lower, upper); - y = U16_to_F32(F32_to_U16(y, lower, upper), lower, upper); - z = U16_to_F32(F32_to_U16(z, lower, upper), lower, upper); - s = U16_to_F32(F32_to_U16(s, lower, upper), lower, upper); + x = U16_to_F32(F32_to_U16_ROUND(x, lower, upper), lower, upper); + y = U16_to_F32(F32_to_U16_ROUND(y, lower, upper), lower, upper); + z = U16_to_F32(F32_to_U16_ROUND(z, lower, upper), lower, upper); + s = U16_to_F32(F32_to_U16_ROUND(s, lower, upper), lower, upper); mQ[VX] = x; mQ[VY] = y; mQ[VZ] = z; mQ[VS] = s; + + normQuat(); } void LLQuaternion::quantize8(F32 lower, F32 upper) { - mQ[VX] = U8_to_F32(F32_to_U8(mQ[VX], lower, upper), lower, upper); - mQ[VY] = U8_to_F32(F32_to_U8(mQ[VY], lower, upper), lower, upper); - mQ[VZ] = U8_to_F32(F32_to_U8(mQ[VZ], lower, upper), lower, upper); - mQ[VS] = U8_to_F32(F32_to_U8(mQ[VS], lower, upper), lower, upper); + mQ[VX] = U8_to_F32(F32_to_U8_ROUND(mQ[VX], lower, upper), lower, upper); + mQ[VY] = U8_to_F32(F32_to_U8_ROUND(mQ[VY], lower, upper), lower, upper); + mQ[VZ] = U8_to_F32(F32_to_U8_ROUND(mQ[VZ], lower, upper), lower, upper); + mQ[VS] = U8_to_F32(F32_to_U8_ROUND(mQ[VS], lower, upper), lower, upper); + + normQuat(); } // LLVector3 Magnitude and Normalization Functions diff --git a/linden/indra/llmath/llquaternion.h b/linden/indra/llmath/llquaternion.h index 66a8b40..01ddae9 100644 --- a/linden/indra/llmath/llquaternion.h +++ b/linden/indra/llmath/llquaternion.h @@ -2,6 +2,8 @@ * @file llquaternion.h * @brief LLQuaternion class header file. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLQUATERNION_H diff --git a/linden/indra/llmath/llrand.cpp b/linden/indra/llmath/llrand.cpp index e6c4cc5..11ecd8e 100644 --- a/linden/indra/llmath/llrand.cpp +++ b/linden/indra/llmath/llrand.cpp @@ -2,6 +2,8 @@ * @file llrand.cpp * @brief Global random generator. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -64,7 +67,7 @@ #define LL_USE_SYSTEM_RAND 0 #if LL_USE_SYSTEM_RAND -#include +#include #endif #if LL_USE_SYSTEM_RAND diff --git a/linden/indra/llmath/llrand.h b/linden/indra/llmath/llrand.h index c5ab7e3..5bd874b 100644 --- a/linden/indra/llmath/llrand.h +++ b/linden/indra/llmath/llrand.h @@ -2,6 +2,8 @@ * @file llrand.h * @brief Information, functions, and typedefs for randomness. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLRAND_H diff --git a/linden/indra/llmath/llrect.cpp b/linden/indra/llmath/llrect.cpp index d9efe45..f7825fa 100644 --- a/linden/indra/llmath/llrect.cpp +++ b/linden/indra/llmath/llrect.cpp @@ -1,6 +1,8 @@ /** * @file llrect.cpp * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmath/llrect.h b/linden/indra/llmath/llrect.h index 38a4983..00a1b03 100644 --- a/linden/indra/llmath/llrect.h +++ b/linden/indra/llmath/llrect.h @@ -2,6 +2,8 @@ * @file llrect.h * @brief A rectangle in GL coordinates, with bottom,left = 0,0 * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ diff --git a/linden/indra/llmath/lltreenode.h b/linden/indra/llmath/lltreenode.h index 8a8710f..6cafee0 100644 --- a/linden/indra/llmath/lltreenode.h +++ b/linden/indra/llmath/lltreenode.h @@ -1,6 +1,8 @@ /** * @file lltreenode.h * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTREENODE_H diff --git a/linden/indra/llmath/lluuid.cpp b/linden/indra/llmath/lluuid.cpp index 97d8c1c..1a7f90f 100644 --- a/linden/indra/llmath/lluuid.cpp +++ b/linden/indra/llmath/lluuid.cpp @@ -1,6 +1,8 @@ /** * @file lluuid.cpp * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -34,7 +37,6 @@ # include #endif -#include "stdtypes.h" #include "lldefs.h" #include "llerror.h" @@ -516,8 +518,6 @@ S32 LLUUID::getNodeID(unsigned char * node_id) /* * Get an ethernet hardware address, if we can find it... */ -#include -#include #include #include #include @@ -598,11 +598,8 @@ S32 LLUUID::getNodeID(unsigned char *node_id) * Get the ethernet hardware address, if we can find it... */ #include -#include -#include #include #include -#include #include #include #include diff --git a/linden/indra/llmath/lluuid.h b/linden/indra/llmath/lluuid.h index 6334ea4..ebe6e2f 100644 --- a/linden/indra/llmath/lluuid.h +++ b/linden/indra/llmath/lluuid.h @@ -1,6 +1,8 @@ /** * @file lluuid.h * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLUUID_H diff --git a/linden/indra/llmath/llv4math.h b/linden/indra/llmath/llv4math.h index 2853ab6..9ad689b 100644 --- a/linden/indra/llmath/llv4math.h +++ b/linden/indra/llmath/llv4math.h @@ -2,7 +2,9 @@ * @file llv4math.h * @brief LLV4* class header file - vector processor enabled math * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLV4MATH_H diff --git a/linden/indra/llmath/llv4matrix3.h b/linden/indra/llmath/llv4matrix3.h index 0811338..bed09d0 100644 --- a/linden/indra/llmath/llv4matrix3.h +++ b/linden/indra/llmath/llv4matrix3.h @@ -2,7 +2,9 @@ * @file llviewerjointmesh.cpp * @brief LLV4* class header file - vector processor enabled math * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLV4MATRIX3_H diff --git a/linden/indra/llmath/llv4matrix4.h b/linden/indra/llmath/llv4matrix4.h index 38280a2..8ffb9d3 100644 --- a/linden/indra/llmath/llv4matrix4.h +++ b/linden/indra/llmath/llv4matrix4.h @@ -2,7 +2,9 @@ * @file llviewerjointmesh.cpp * @brief LLV4* class header file - vector processor enabled math * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLV4MATRIX4_H diff --git a/linden/indra/llmath/llv4vector3.h b/linden/indra/llmath/llv4vector3.h index 994e7f5..e176908 100644 --- a/linden/indra/llmath/llv4vector3.h +++ b/linden/indra/llmath/llv4vector3.h @@ -2,7 +2,9 @@ * @file llviewerjointmesh.cpp * @brief LLV4* class header file - vector processor enabled math * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLV4VECTOR3_H diff --git a/linden/indra/llmath/llvolume.cpp b/linden/indra/llmath/llvolume.cpp index 7f2a663..9cad612 100644 --- a/linden/indra/llmath/llvolume.cpp +++ b/linden/indra/llmath/llvolume.cpp @@ -1,6 +1,8 @@ /** * @file llvolume.cpp * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -83,6 +86,8 @@ const S32 SCULPT_REZ_2 = 8; const S32 SCULPT_REZ_3 = 16; const S32 SCULPT_REZ_4 = 32; +const F32 SCULPT_MIN_AREA = 0.005f; + BOOL check_same_clock_dir( const LLVector3& pt1, const LLVector3& pt2, const LLVector3& pt3, const LLVector3& norm) { LLVector3 test = (pt2-pt1)%(pt3-pt2); @@ -1825,6 +1830,18 @@ void LLVolume::createVolumeFaces() } +inline LLVector3 sculpt_rgb_to_vector(U8 r, U8 g, U8 b) +{ + // maps RGB values to vector values [0..255] -> [-0.5..0.5] + LLVector3 value; + value.mV[VX] = r / 256.f - 0.5f; + value.mV[VY] = g / 256.f - 0.5f; + value.mV[VZ] = b / 256.f - 0.5f; + + return value; +} + + // sculpt replaces generate() for sculpted surfaces void LLVolume::sculpt(U16 sculpt_width, U16 sculpt_height, S8 sculpt_components, const U8* sculpt_data, S32 sculpt_level) { @@ -1849,40 +1866,39 @@ void LLVolume::sculpt(U16 sculpt_width, U16 sculpt_height, S8 sculpt_components, mMesh.resize(sizeS * sizeT); sNumMeshPoints += mMesh.size(); - S32 vertex_change = 0; + F32 area = 0; // first test to see if image has enough variation to create non-degenerate geometry if (!data_is_empty) { - S32 last_index = 0; - for (S32 s = 0; s < sizeS; s++) - for (S32 t = 0; t < sizeT; t++) + for (S32 s = 0; s < sizeS - 1; s++) + for (S32 t = 0; t < sizeT - 1; t++) { - U32 x = (U32) ((F32)s/(sizeS-1) * (F32) sculpt_width); - U32 y = (U32) ((F32)t/(sizeT-1) * (F32) sculpt_height); + // first coordinate + U32 x = (U32) ((F32)s/(sizeS) * (F32) sculpt_width); + U32 y = (U32) ((F32)t/(sizeT) * (F32) sculpt_height); - if (y == sculpt_height) // stitch bottom - { - y = sculpt_height - 1; - x = sculpt_width / 2; - } - - if (x == sculpt_width) // stitch sides - x = 0; - - if (y == 0) // stitch top - x = sculpt_width / 2; - - U32 index = (x + y * sculpt_width) * sculpt_components; - - if (fabs((F32)(sculpt_data[index] - sculpt_data[last_index])) + - fabs((F32)(sculpt_data[index+1] - sculpt_data[last_index+1])) + - fabs((F32)(sculpt_data[index+2] - sculpt_data[last_index+2])) > 0) - vertex_change++; - - last_index = index; + // coordinate offset by 1 + U32 x2 = (U32) ((F32)(s+1)/(sizeS) * (F32) sculpt_width); + U32 y2 = (U32) ((F32)(t+1)/(sizeT) * (F32) sculpt_height); + + // three points on a triagle - find the image indices first + U32 p1_index = (x + y * sculpt_width) * sculpt_components; + U32 p2_index = (x2 + y * sculpt_width) * sculpt_components; + U32 p3_index = (x + y2 * sculpt_width) * sculpt_components; + + // convert image data to vectors + LLVector3 p1 = sculpt_rgb_to_vector(sculpt_data[p1_index], sculpt_data[p1_index+1], sculpt_data[p1_index+2]); + LLVector3 p2 = sculpt_rgb_to_vector(sculpt_data[p2_index], sculpt_data[p2_index+1], sculpt_data[p2_index+2]); + LLVector3 p3 = sculpt_rgb_to_vector(sculpt_data[p3_index], sculpt_data[p3_index+1], sculpt_data[p3_index+2]); + + // compute the area of the parallelogram by taking the length of the cross product: + // (parallegram is an approximation of two triangles) + LLVector3 cross = (p1 - p2) % (p1 - p3); + // take length squared for efficiency (no sqrt) + area += cross.magVecSquared(); } - if ((F32)vertex_change / sizeS / sizeT < 0.02) // less than 2% + if (area < SCULPT_MIN_AREA * SCULPT_MIN_AREA) data_is_empty = TRUE; } @@ -1974,9 +1990,7 @@ void LLVolume::sculpt(U16 sculpt_width, U16 sculpt_height, S8 sculpt_components, U32 index = (x + y * sculpt_width) * sculpt_components; - pt.mPos.mV[0] = sculpt_data[index ] / 256.f - 0.5f; - pt.mPos.mV[1] = sculpt_data[index+1] / 256.f - 0.5f; - pt.mPos.mV[2] = sculpt_data[index+2] / 256.f - 0.5f; + pt.mPos = sculpt_rgb_to_vector(sculpt_data[index], sculpt_data[index+1], sculpt_data[index+2]); } line += sizeT; } diff --git a/linden/indra/llmath/llvolume.h b/linden/indra/llmath/llvolume.h index ee28057..3dadc56 100644 --- a/linden/indra/llmath/llvolume.h +++ b/linden/indra/llmath/llvolume.h @@ -2,6 +2,8 @@ * @file llvolume.h * @brief LLVolume base class. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVOLUME_H diff --git a/linden/indra/llmath/llvolumemgr.cpp b/linden/indra/llmath/llvolumemgr.cpp index eac407f..eae6ab7 100644 --- a/linden/indra/llmath/llvolumemgr.cpp +++ b/linden/indra/llmath/llvolumemgr.cpp @@ -1,6 +1,8 @@ /** * @file llvolumemgr.cpp * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmath/llvolumemgr.h b/linden/indra/llmath/llvolumemgr.h index aa00c4e..7aa0a3f 100644 --- a/linden/indra/llmath/llvolumemgr.h +++ b/linden/indra/llmath/llvolumemgr.h @@ -2,6 +2,8 @@ * @file llvolumemgr.h * @brief LLVolumeMgr class. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVOLUMEMGR_H diff --git a/linden/indra/llmath/m3math.cpp b/linden/indra/llmath/m3math.cpp index 09a18d2..d4f99cb 100644 --- a/linden/indra/llmath/m3math.cpp +++ b/linden/indra/llmath/m3math.cpp @@ -2,6 +2,8 @@ * @file m3math.cpp * @brief LLMatrix3 class implementation. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmath/m3math.h b/linden/indra/llmath/m3math.h index 94c9b65..d2848aa 100644 --- a/linden/indra/llmath/m3math.h +++ b/linden/indra/llmath/m3math.h @@ -2,6 +2,8 @@ * @file m3math.h * @brief LLMatrix3 class header file. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_M3MATH_H diff --git a/linden/indra/llmath/m4math.cpp b/linden/indra/llmath/m4math.cpp index b6d91a1..4e7cf84 100644 --- a/linden/indra/llmath/m4math.cpp +++ b/linden/indra/llmath/m4math.cpp @@ -2,6 +2,8 @@ * @file m4math.cpp * @brief LLMatrix4 class implementation. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmath/m4math.h b/linden/indra/llmath/m4math.h index 24f9f86..4958777 100644 --- a/linden/indra/llmath/m4math.h +++ b/linden/indra/llmath/m4math.h @@ -2,6 +2,8 @@ * @file m4math.h * @brief LLMatrix3 class header file. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_M4MATH_H diff --git a/linden/indra/llmath/raytrace.cpp b/linden/indra/llmath/raytrace.cpp index 634542d..fbdc6cf 100644 --- a/linden/indra/llmath/raytrace.cpp +++ b/linden/indra/llmath/raytrace.cpp @@ -2,6 +2,8 @@ * @file raytrace.cpp * @brief Functions called by box object scripts. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmath/raytrace.h b/linden/indra/llmath/raytrace.h index f68002f..0735b87 100644 --- a/linden/indra/llmath/raytrace.h +++ b/linden/indra/llmath/raytrace.h @@ -2,6 +2,8 @@ * @file raytrace.h * @brief Ray intersection tests for primitives. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_RAYTRACE_H diff --git a/linden/indra/llmath/v2math.cpp b/linden/indra/llmath/v2math.cpp index e41227b..7033048 100644 --- a/linden/indra/llmath/v2math.cpp +++ b/linden/indra/llmath/v2math.cpp @@ -2,6 +2,8 @@ * @file v2math.cpp * @brief LLVector2 class implementation. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmath/v2math.h b/linden/indra/llmath/v2math.h index bcfe016..f2450b1 100644 --- a/linden/indra/llmath/v2math.h +++ b/linden/indra/llmath/v2math.h @@ -2,6 +2,8 @@ * @file v2math.h * @brief LLVector2 class header file. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,13 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_V2MATH_H #define LL_V2MATH_H -#include - #include "llmath.h" class LLVector4; diff --git a/linden/indra/llmath/v3color.cpp b/linden/indra/llmath/v3color.cpp index 5378bc5..462075c 100644 --- a/linden/indra/llmath/v3color.cpp +++ b/linden/indra/llmath/v3color.cpp @@ -2,6 +2,8 @@ * @file v3color.cpp * @brief LLColor3 class implementation. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmath/v3color.h b/linden/indra/llmath/v3color.h index 8f9224d..b80fa06 100644 --- a/linden/indra/llmath/v3color.h +++ b/linden/indra/llmath/v3color.h @@ -2,6 +2,8 @@ * @file v3color.h * @brief LLColor3 class header file. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_V3COLOR_H diff --git a/linden/indra/llmath/v3dmath.cpp b/linden/indra/llmath/v3dmath.cpp index 059f9c6..efe1274 100644 --- a/linden/indra/llmath/v3dmath.cpp +++ b/linden/indra/llmath/v3dmath.cpp @@ -2,6 +2,8 @@ * @file v3dmath.cpp * @brief LLVector3d class implementation. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmath/v3dmath.h b/linden/indra/llmath/v3dmath.h index c101cc8..ac3f06c 100644 --- a/linden/indra/llmath/v3dmath.h +++ b/linden/indra/llmath/v3dmath.h @@ -2,6 +2,8 @@ * @file v3dmath.h * @brief High precision 3 dimensional vector. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_V3DMATH_H diff --git a/linden/indra/llmath/v3math.cpp b/linden/indra/llmath/v3math.cpp index f42fe1c..5ffd1dd 100644 --- a/linden/indra/llmath/v3math.cpp +++ b/linden/indra/llmath/v3math.cpp @@ -2,6 +2,8 @@ * @file v3math.cpp * @brief LLVector3 class implementation. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmath/v3math.h b/linden/indra/llmath/v3math.h index bf211e2..e18b20d 100644 --- a/linden/indra/llmath/v3math.h +++ b/linden/indra/llmath/v3math.h @@ -2,6 +2,8 @@ * @file v3math.h * @brief LLVector3 class header file. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_V3MATH_H diff --git a/linden/indra/llmath/v4color.cpp b/linden/indra/llmath/v4color.cpp index 281e5f1..4ce8e10 100644 --- a/linden/indra/llmath/v4color.cpp +++ b/linden/indra/llmath/v4color.cpp @@ -2,6 +2,8 @@ * @file v4color.cpp * @brief LLColor4 class implementation. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmath/v4color.h b/linden/indra/llmath/v4color.h index 2e9d13f..1e6232f 100644 --- a/linden/indra/llmath/v4color.h +++ b/linden/indra/llmath/v4color.h @@ -2,6 +2,8 @@ * @file v4color.h * @brief LLColor4 class header file. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_V4COLOR_H diff --git a/linden/indra/llmath/v4coloru.cpp b/linden/indra/llmath/v4coloru.cpp index 90399b5..6f6900b 100644 --- a/linden/indra/llmath/v4coloru.cpp +++ b/linden/indra/llmath/v4coloru.cpp @@ -2,6 +2,8 @@ * @file v4coloru.cpp * @brief LLColor4U class implementation. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmath/v4coloru.h b/linden/indra/llmath/v4coloru.h index 08e723a..fc7845a 100644 --- a/linden/indra/llmath/v4coloru.h +++ b/linden/indra/llmath/v4coloru.h @@ -2,6 +2,8 @@ * @file v4coloru.h * @brief The LLColor4U class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_V4COLORU_H diff --git a/linden/indra/llmath/v4math.cpp b/linden/indra/llmath/v4math.cpp index fa52d95..b753778 100644 --- a/linden/indra/llmath/v4math.cpp +++ b/linden/indra/llmath/v4math.cpp @@ -2,6 +2,8 @@ * @file v4math.cpp * @brief LLVector4 class implementation. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmath/v4math.h b/linden/indra/llmath/v4math.h index f3c2ccc..57dcad3 100644 --- a/linden/indra/llmath/v4math.h +++ b/linden/indra/llmath/v4math.h @@ -2,6 +2,8 @@ * @file v4math.h * @brief LLVector4 class header file. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_V4MATH_H diff --git a/linden/indra/llmath/xform.cpp b/linden/indra/llmath/xform.cpp index 71c2755..8399dfb 100644 --- a/linden/indra/llmath/xform.cpp +++ b/linden/indra/llmath/xform.cpp @@ -1,6 +1,8 @@ /** * @file xform.cpp * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmath/xform.h b/linden/indra/llmath/xform.h index 605b1b5..9a5c991 100644 --- a/linden/indra/llmath/xform.h +++ b/linden/indra/llmath/xform.h @@ -1,6 +1,8 @@ /** * @file xform.h * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_XFORM_H @@ -32,9 +35,6 @@ #include "m4math.h" #include "llquaternion.h" -#define CHECK_FOR_FINITE - - const F32 MAX_OBJECT_Z = 768.f; const F32 MIN_OBJECT_Z = -256.f; const F32 MIN_OBJECT_SCALE = 0.01f; @@ -180,14 +180,16 @@ BOOL LLXform::setParent(LLXform* parent) return TRUE; } -#ifdef CHECK_FOR_FINITE void LLXform::setPosition(const LLVector3& pos) { setChanged(TRANSLATED); if (pos.isFinite()) mPosition = pos; else - llerror("Non Finite in LLXform::setPosition(LLVector3)", 0); + { + mPosition.clearVec(); + llwarns << "Non Finite in LLXform::setPosition(LLVector3)" << llendl; + } } void LLXform::setPosition(const F32 x, const F32 y, const F32 z) @@ -196,7 +198,10 @@ void LLXform::setPosition(const F32 x, const F32 y, const F32 z) if (llfinite(x) && llfinite(y) && llfinite(z)) mPosition.setVec(x,y,z); else - llerror("Non Finite in LLXform::setPosition(F32,F32,F32)", 0); + { + mPosition.clearVec(); + llwarns << "Non Finite in LLXform::setPosition(F32,F32,F32)" << llendl; + } } void LLXform::setPositionX(const F32 x) @@ -205,7 +210,10 @@ void LLXform::setPositionX(const F32 x) if (llfinite(x)) mPosition.mV[VX] = x; else - llerror("Non Finite in LLXform::setPositionX", 0); + { + mPosition.mV[VX] = 0.f; + llwarns << "Non Finite in LLXform::setPositionX" << llendl; + } } void LLXform::setPositionY(const F32 y) @@ -214,7 +222,10 @@ void LLXform::setPositionY(const F32 y) if (llfinite(y)) mPosition.mV[VY] = y; else - llerror("Non Finite in LLXform::setPositionY", 0); + { + mPosition.mV[VY] = 0.f; + llwarns << "Non Finite in LLXform::setPositionY" << llendl; + } } void LLXform::setPositionZ(const F32 z) @@ -223,7 +234,10 @@ void LLXform::setPositionZ(const F32 z) if (llfinite(z)) mPosition.mV[VZ] = z; else - llerror("Non Finite in LLXform::setPositionZ", 0); + { + mPosition.mV[VZ] = 0.f; + llwarns << "Non Finite in LLXform::setPositionZ" << llendl; + } } void LLXform::addPosition(const LLVector3& pos) @@ -232,7 +246,7 @@ void LLXform::addPosition(const LLVector3& pos) if (pos.isFinite()) mPosition += pos; else - llerror("Non Finite in LLXform::addPosition", 0); + llwarns << "Non Finite in LLXform::addPosition" << llendl; } void LLXform::setScale(const LLVector3& scale) @@ -241,7 +255,10 @@ void LLXform::setScale(const LLVector3& scale) if (scale.isFinite()) mScale = scale; else - llerror("Non Finite in LLXform::setScale", 0); + { + mScale.setVec(1.f, 1.f, 1.f); + llwarns << "Non Finite in LLXform::setScale" << llendl; + } } void LLXform::setScale(const F32 x, const F32 y, const F32 z) { @@ -249,7 +266,10 @@ void LLXform::setScale(const F32 x, const F32 y, const F32 z) if (llfinite(x) && llfinite(y) && llfinite(z)) mScale.setVec(x,y,z); else - llerror("Non Finite in LLXform::setScale", 0); + { + mScale.setVec(1.f, 1.f, 1.f); + llwarns << "Non Finite in LLXform::setScale" << llendl; + } } void LLXform::setRotation(const LLQuaternion& rot) { @@ -257,7 +277,10 @@ void LLXform::setRotation(const LLQuaternion& rot) if (rot.isFinite()) mRotation = rot; else - llerror("Non Finite in LLXform::setRotation", 0); + { + mRotation.loadIdentity(); + llwarns << "Non Finite in LLXform::setRotation" << llendl; + } } void LLXform::setRotation(const F32 x, const F32 y, const F32 z) { @@ -268,7 +291,8 @@ void LLXform::setRotation(const F32 x, const F32 y, const F32 z) } else { - llerror("Non Finite in LLXform::setRotation", 0); + mRotation.loadIdentity(); + llwarns << "Non Finite in LLXform::setRotation" << llendl; } } void LLXform::setRotation(const F32 x, const F32 y, const F32 z, const F32 s) @@ -280,10 +304,9 @@ void LLXform::setRotation(const F32 x, const F32 y, const F32 z, const F32 s) } else { - llerror("Non Finite in LLXform::setRotation", 0); + mRotation.loadIdentity(); + llwarns << "Non Finite in LLXform::setRotation" << llendl; } } #endif - -#endif diff --git a/linden/indra/llmedia/llmediabase.cpp b/linden/indra/llmedia/llmediabase.cpp index 17bb563..312df3a 100644 --- a/linden/indra/llmedia/llmediabase.cpp +++ b/linden/indra/llmedia/llmediabase.cpp @@ -2,6 +2,8 @@ * @file llmediabase.cpp * @brief LLMedia support - base class * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmedia/llmediabase.h b/linden/indra/llmedia/llmediabase.h index f78c7ad..dfb3029 100644 --- a/linden/indra/llmedia/llmediabase.h +++ b/linden/indra/llmedia/llmediabase.h @@ -2,6 +2,8 @@ * @file llmediabase.h * @brief LLMedia support - base class * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // header guard diff --git a/linden/indra/llmedia/llmediaemitter.h b/linden/indra/llmedia/llmediaemitter.h index 0560f16..8d67442 100644 --- a/linden/indra/llmedia/llmediaemitter.h +++ b/linden/indra/llmedia/llmediaemitter.h @@ -2,6 +2,8 @@ * @file llmediaemitter.h * @brief LLMedia support - templatized emitter class. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // header guard diff --git a/linden/indra/llmedia/llmediaemitterevents.h b/linden/indra/llmedia/llmediaemitterevents.h index 632f863..4c4c770 100644 --- a/linden/indra/llmedia/llmediaemitterevents.h +++ b/linden/indra/llmedia/llmediaemitterevents.h @@ -2,6 +2,8 @@ * @file llmediaemitterevents.h * @brief LLMedia support - events emitted by emitter to observer. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // header guard diff --git a/linden/indra/llmedia/llmediaengine.cpp b/linden/indra/llmedia/llmediaengine.cpp index c75ed32..c0e904b 100644 --- a/linden/indra/llmedia/llmediaengine.cpp +++ b/linden/indra/llmedia/llmediaengine.cpp @@ -2,6 +2,8 @@ * @file llmediaengine.cpp * @brief Top level media engine - wraps more specific functionality * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmedia/llmediaengine.h b/linden/indra/llmedia/llmediaengine.h index 775837b..e585c13 100644 --- a/linden/indra/llmedia/llmediaengine.h +++ b/linden/indra/llmedia/llmediaengine.h @@ -2,6 +2,8 @@ * @file llmediaengine.h * @brief Top level media engine - wraps more specific functionality. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLMEDIAENGINE_H diff --git a/linden/indra/llmedia/llmediaimplgstreamer.cpp b/linden/indra/llmedia/llmediaimplgstreamer.cpp index 36d2e07..157d871 100644 --- a/linden/indra/llmedia/llmediaimplgstreamer.cpp +++ b/linden/indra/llmedia/llmediaimplgstreamer.cpp @@ -2,7 +2,9 @@ * @file llmediaimplgstreamer.cpp * @brief implementation that supports various media through GStreamer. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmedia/llmediaimplgstreamer.h b/linden/indra/llmedia/llmediaimplgstreamer.h index 52a5c84..4c07f62 100644 --- a/linden/indra/llmedia/llmediaimplgstreamer.h +++ b/linden/indra/llmedia/llmediaimplgstreamer.h @@ -2,7 +2,9 @@ * @file llmediaimplgstreamer.h * @brief implementation that supports media playback via GStreamer. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // header guard diff --git a/linden/indra/llmedia/llmediaimplgstreamer_syms.cpp b/linden/indra/llmedia/llmediaimplgstreamer_syms.cpp index 76f62e1..a6a9395 100644 --- a/linden/indra/llmedia/llmediaimplgstreamer_syms.cpp +++ b/linden/indra/llmedia/llmediaimplgstreamer_syms.cpp @@ -2,7 +2,9 @@ * @file llmediaimplgstreamer_syms.cpp * @brief dynamic GStreamer symbol-grabbing code * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmedia/llmediaimplgstreamer_syms.h b/linden/indra/llmedia/llmediaimplgstreamer_syms.h index 6dec2a2..c1bc4e8 100644 --- a/linden/indra/llmedia/llmediaimplgstreamer_syms.h +++ b/linden/indra/llmedia/llmediaimplgstreamer_syms.h @@ -2,7 +2,9 @@ * @file llmediaimplgstreamer_syms.h * @brief dynamic GStreamer symbol-grabbing code * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmedia/llmediaimplgstreamervidplug.cpp b/linden/indra/llmedia/llmediaimplgstreamervidplug.cpp index dade946..1a59654 100644 --- a/linden/indra/llmedia/llmediaimplgstreamervidplug.cpp +++ b/linden/indra/llmedia/llmediaimplgstreamervidplug.cpp @@ -2,7 +2,9 @@ * @file llmediaimplgstreamervidplug.h * @brief Video-consuming static GStreamer plugin for gst-to-LLMediaImpl * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,11 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #if LL_GSTREAMER_ENABLED -#include +#include "linden_common.h" #include #include diff --git a/linden/indra/llmedia/llmediaimplgstreamervidplug.h b/linden/indra/llmedia/llmediaimplgstreamervidplug.h index 2bfb853..223c913 100644 --- a/linden/indra/llmedia/llmediaimplgstreamervidplug.h +++ b/linden/indra/llmedia/llmediaimplgstreamervidplug.h @@ -2,7 +2,9 @@ * @file llmediaimplgstreamervidplug.h * @brief Video-consuming static GStreamer plugin for gst-to-LLMediaImpl * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef __GST_SLVIDEO_H__ diff --git a/linden/indra/llmedia/llmediaimplquicktime.cpp b/linden/indra/llmedia/llmediaimplquicktime.cpp index 6028d51..8bf119f 100644 --- a/linden/indra/llmedia/llmediaimplquicktime.cpp +++ b/linden/indra/llmedia/llmediaimplquicktime.cpp @@ -2,6 +2,8 @@ * @file llmediaimplquicktime.cpp * @brief implementation that supports Apple QuickTime media. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmedia/llmediaimplquicktime.h b/linden/indra/llmedia/llmediaimplquicktime.h index d564d3a..4d6d81d 100644 --- a/linden/indra/llmedia/llmediaimplquicktime.h +++ b/linden/indra/llmedia/llmediaimplquicktime.h @@ -2,6 +2,8 @@ * @file llmediaimplquicktime.h * @brief implementation that supports Apple QuickTime media. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #if LL_QUICKTIME_ENABLED diff --git a/linden/indra/llmedia/llmediamoviebase.cpp b/linden/indra/llmedia/llmediamoviebase.cpp index de9933b..dc3f224 100644 --- a/linden/indra/llmedia/llmediamoviebase.cpp +++ b/linden/indra/llmedia/llmediamoviebase.cpp @@ -2,6 +2,8 @@ * @file llmediamoviebase.cpp * @brief LLMedia support - base class. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmedia/llmediamoviebase.h b/linden/indra/llmedia/llmediamoviebase.h index 91c21d8..6745216 100644 --- a/linden/indra/llmedia/llmediamoviebase.h +++ b/linden/indra/llmedia/llmediamoviebase.h @@ -3,6 +3,8 @@ * @brief LLMedia support - intermediate base class, for media types * that want movie-style controls (i.e play/pause and volume) * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // header guard diff --git a/linden/indra/llmedia/llmediaobservers.h b/linden/indra/llmedia/llmediaobservers.h index c45005d..960cb0d 100644 --- a/linden/indra/llmedia/llmediaobservers.h +++ b/linden/indra/llmedia/llmediaobservers.h @@ -2,6 +2,8 @@ * @file llmediaobservers.h * @brief LLMedia support - observer classes to be overridden. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // header guard diff --git a/linden/indra/llmessage/llassetstorage.cpp b/linden/indra/llmessage/llassetstorage.cpp index b1d7fef..d5e0445 100644 --- a/linden/indra/llmessage/llassetstorage.cpp +++ b/linden/indra/llmessage/llassetstorage.cpp @@ -2,6 +2,8 @@ * @file llassetstorage.cpp * @brief Implementation of the base asset storage system. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,16 +26,14 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" // system library includes -#include -#include #include #include -#include #include "llassetstorage.h" diff --git a/linden/indra/llmessage/llassetstorage.h b/linden/indra/llmessage/llassetstorage.h index 630268d..e2ccf2c 100644 --- a/linden/indra/llmessage/llassetstorage.h +++ b/linden/indra/llmessage/llassetstorage.h @@ -3,6 +3,8 @@ * @brief definition of LLAssetStorage class which allows simple * up/downloads of uuid,type asets * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLASSETSTORAGE_H diff --git a/linden/indra/llmessage/llblowfishcipher.cpp b/linden/indra/llmessage/llblowfishcipher.cpp index 62464de..7c9194d 100644 --- a/linden/indra/llmessage/llblowfishcipher.cpp +++ b/linden/indra/llmessage/llblowfishcipher.cpp @@ -5,7 +5,9 @@ * We do not have OpenSSL headers or libraries on Windows, so this * class only works on Linux. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -27,6 +29,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llblowfishcipher.h b/linden/indra/llmessage/llblowfishcipher.h index 0ba1473..f477184 100644 --- a/linden/indra/llmessage/llblowfishcipher.h +++ b/linden/indra/llmessage/llblowfishcipher.h @@ -5,7 +5,9 @@ * two UUIDs and a timestamp (16x2 + 4 = 36 bytes) with only 40 bytes of * output. AES has a block size of 32 bytes, so this would require 64 bytes. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -27,6 +29,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLBLOWFISHCIPHER_H diff --git a/linden/indra/llmessage/llbuffer.cpp b/linden/indra/llmessage/llbuffer.cpp index ad822bc..c3433e9 100644 --- a/linden/indra/llmessage/llbuffer.cpp +++ b/linden/indra/llmessage/llbuffer.cpp @@ -4,6 +4,8 @@ * @date 2005-09-20 * @brief Implementation of the segments, buffers, and buffer arrays. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llbuffer.h b/linden/indra/llmessage/llbuffer.h index 63f7bea..b251af8 100644 --- a/linden/indra/llmessage/llbuffer.h +++ b/linden/indra/llmessage/llbuffer.h @@ -4,6 +4,8 @@ * @date 2005-09-20 * @brief Declaration of buffer and buffer arrays primarily used in I/O. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLBUFFER_H diff --git a/linden/indra/llmessage/llbufferstream.cpp b/linden/indra/llmessage/llbufferstream.cpp index 4a4d892..72310a5 100644 --- a/linden/indra/llmessage/llbufferstream.cpp +++ b/linden/indra/llmessage/llbufferstream.cpp @@ -4,6 +4,8 @@ * @date 2005-10-10 * @brief Implementation of the buffer iostream classes * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llbufferstream.h b/linden/indra/llmessage/llbufferstream.h index 5447a80..78b7f3c 100644 --- a/linden/indra/llmessage/llbufferstream.h +++ b/linden/indra/llmessage/llbufferstream.h @@ -4,6 +4,8 @@ * @date 2005-10-10 * @brief Classes to treat an LLBufferArray as a c++ iostream. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLBUFFERSTREAM_H diff --git a/linden/indra/llmessage/llcachename.cpp b/linden/indra/llmessage/llcachename.cpp index d960429..f731c95 100644 --- a/linden/indra/llmessage/llcachename.cpp +++ b/linden/indra/llmessage/llcachename.cpp @@ -2,6 +2,8 @@ * @file llcachename.cpp * @brief A hierarchical cache of first and last names queried based on UUID. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,20 +25,14 @@ * * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, - * COMPLETENESS OR PERFORMANCE. + * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" #include "llcachename.h" -// system includes -#include // strcpy -#include -#include -#include -#include - // linden library includes #include "message.h" #include "llrand.h" diff --git a/linden/indra/llmessage/llcachename.h b/linden/indra/llmessage/llcachename.h index d1a5cfe..ab62829 100644 --- a/linden/indra/llmessage/llcachename.h +++ b/linden/indra/llmessage/llcachename.h @@ -2,6 +2,8 @@ * @file llcachename.h * @brief A cache of names from UUIDs. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,14 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCACHENAME_H #define LL_LLCACHENAME_H -// Forward declarations -#include - class LLMessageSystem; class LLHost; class LLUUID; diff --git a/linden/indra/llmessage/llcallbacklisth.h b/linden/indra/llmessage/llcallbacklisth.h index 74dbcc8..eee3977 100644 --- a/linden/indra/llmessage/llcallbacklisth.h +++ b/linden/indra/llmessage/llcallbacklisth.h @@ -3,6 +3,8 @@ * @brief Like LLCallbackList but uses handles instead of pointers for * user data * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCALLBACKLISTH_H diff --git a/linden/indra/llmessage/llchainio.cpp b/linden/indra/llmessage/llchainio.cpp index 47352d1..226ee10 100644 --- a/linden/indra/llmessage/llchainio.cpp +++ b/linden/indra/llmessage/llchainio.cpp @@ -4,6 +4,8 @@ * @date 2005-08-04 * @brief Implementaiton of the chain factory. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llchainio.h b/linden/indra/llmessage/llchainio.h index ef2747a..3e32956 100644 --- a/linden/indra/llmessage/llchainio.h +++ b/linden/indra/llmessage/llchainio.h @@ -4,6 +4,8 @@ * @date 2005-08-04 * @brief This class declares the interface for constructing io chains. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCHAINIO_H diff --git a/linden/indra/llmessage/llcipher.h b/linden/indra/llmessage/llcipher.h index 1860277..669c8aa 100644 --- a/linden/indra/llmessage/llcipher.h +++ b/linden/indra/llmessage/llcipher.h @@ -2,6 +2,8 @@ * @file llcipher.h * @brief Abstract base class for encryption ciphers. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLCIPHER_H diff --git a/linden/indra/llmessage/llcircuit.cpp b/linden/indra/llmessage/llcircuit.cpp index 3c947d9..1d1be56 100644 --- a/linden/indra/llmessage/llcircuit.cpp +++ b/linden/indra/llmessage/llcircuit.cpp @@ -2,6 +2,8 @@ * @file llcircuit.cpp * @brief Class to track UDP endpoints for the message system. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llcircuit.h b/linden/indra/llmessage/llcircuit.h index 33c0e10..128b1bc 100644 --- a/linden/indra/llmessage/llcircuit.h +++ b/linden/indra/llmessage/llcircuit.h @@ -3,6 +3,8 @@ * @brief Provides a method for tracking network circuit information * for the UDP message system * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCIRCUIT_H diff --git a/linden/indra/llmessage/llclassifiedflags.cpp b/linden/indra/llmessage/llclassifiedflags.cpp index ed595b1..b34ebfe 100644 --- a/linden/indra/llmessage/llclassifiedflags.cpp +++ b/linden/indra/llmessage/llclassifiedflags.cpp @@ -2,6 +2,8 @@ * @file llclassifiedflags.cpp * @brief * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //***************************************************************************** diff --git a/linden/indra/llmessage/llclassifiedflags.h b/linden/indra/llmessage/llclassifiedflags.h index a2a93d8..bcd03d9 100644 --- a/linden/indra/llmessage/llclassifiedflags.h +++ b/linden/indra/llmessage/llclassifiedflags.h @@ -2,6 +2,8 @@ * @file llclassifiedflags.h * @brief Flags used in the classifieds. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCLASSIFIEDFLAGS_H diff --git a/linden/indra/llmessage/llcurl.cpp b/linden/indra/llmessage/llcurl.cpp index b94a41e..01976b1 100644 --- a/linden/indra/llmessage/llcurl.cpp +++ b/linden/indra/llmessage/llcurl.cpp @@ -4,6 +4,8 @@ * @date 2006-10-15 * @brief Curl wrapper * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llcurl.h b/linden/indra/llmessage/llcurl.h index 2d7d5d8..d21cdc4 100644 --- a/linden/indra/llmessage/llcurl.h +++ b/linden/indra/llmessage/llcurl.h @@ -4,6 +4,8 @@ * @date 2006-10-15 * @brief Curl wrapper * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCURL_H diff --git a/linden/indra/llmessage/lldatapacker.cpp b/linden/indra/llmessage/lldatapacker.cpp index 8725870..2ebd1b7 100644 --- a/linden/indra/llmessage/lldatapacker.cpp +++ b/linden/indra/llmessage/lldatapacker.cpp @@ -2,6 +2,8 @@ * @file lldatapacker.cpp * @brief Data packer implementation. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,10 +26,9 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ -#include - #include "linden_common.h" #include "lldatapacker.h" diff --git a/linden/indra/llmessage/lldatapacker.h b/linden/indra/llmessage/lldatapacker.h index 700f8fb..ff33d4e 100644 --- a/linden/indra/llmessage/lldatapacker.h +++ b/linden/indra/llmessage/lldatapacker.h @@ -2,6 +2,8 @@ * @file lldatapacker.h * @brief Data packer declaration for tightly storing binary data. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,16 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDATAPACKER_H #define LL_LLDATAPACKER_H -#include -#include - -#include "llerror.h" - class LLColor4; class LLColor4U; class LLVector2; diff --git a/linden/indra/llmessage/lldbstrings.h b/linden/indra/llmessage/lldbstrings.h index dd249b1..f36f4c4 100644 --- a/linden/indra/llmessage/lldbstrings.h +++ b/linden/indra/llmessage/lldbstrings.h @@ -2,6 +2,8 @@ * @file lldbstrings.h * @brief Database String Lengths. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDBSTRINGS_H diff --git a/linden/indra/llmessage/lldispatcher.cpp b/linden/indra/llmessage/lldispatcher.cpp index 2e775f9..d0e1e68 100644 --- a/linden/indra/llmessage/lldispatcher.cpp +++ b/linden/indra/llmessage/lldispatcher.cpp @@ -2,6 +2,8 @@ * @file lldispatcher.cpp * @brief Implementation of the dispatcher object. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/lldispatcher.h b/linden/indra/llmessage/lldispatcher.h index 374ee0d..452be7c 100644 --- a/linden/indra/llmessage/lldispatcher.h +++ b/linden/indra/llmessage/lldispatcher.h @@ -2,6 +2,8 @@ * @file lldispatcher.h * @brief LLDispatcher class header file. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDISPATCHER_H diff --git a/linden/indra/llmessage/lleventflags.h b/linden/indra/llmessage/lleventflags.h index f6b89e3..9a5b889 100644 --- a/linden/indra/llmessage/lleventflags.h +++ b/linden/indra/llmessage/lleventflags.h @@ -2,6 +2,8 @@ * @file lleventflags.h * @brief Flags for events. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLEVENTFLAGS_H diff --git a/linden/indra/llmessage/llfiltersd2xmlrpc.cpp b/linden/indra/llmessage/llfiltersd2xmlrpc.cpp index 34a4621..eac7dc1 100644 --- a/linden/indra/llmessage/llfiltersd2xmlrpc.cpp +++ b/linden/indra/llmessage/llfiltersd2xmlrpc.cpp @@ -3,6 +3,8 @@ * @author Phoenix * @date 2005-04-26 * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /** diff --git a/linden/indra/llmessage/llfiltersd2xmlrpc.h b/linden/indra/llmessage/llfiltersd2xmlrpc.h index 8b2f066..c82a518 100644 --- a/linden/indra/llmessage/llfiltersd2xmlrpc.h +++ b/linden/indra/llmessage/llfiltersd2xmlrpc.h @@ -3,6 +3,8 @@ * @author Phoenix * @date 2005-04-26 * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFILTERSD2XMLRPC_H diff --git a/linden/indra/llmessage/llfollowcamparams.h b/linden/indra/llmessage/llfollowcamparams.h index 0979474..0affcf9 100644 --- a/linden/indra/llmessage/llfollowcamparams.h +++ b/linden/indra/llmessage/llfollowcamparams.h @@ -2,6 +2,8 @@ * @file llfollowcamparams.h * @brief Follow camera parameters. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_FOLLOWCAM_PARAMS_H diff --git a/linden/indra/llmessage/llhost.cpp b/linden/indra/llmessage/llhost.cpp index d57d52d..b73becf 100644 --- a/linden/indra/llmessage/llhost.cpp +++ b/linden/indra/llmessage/llhost.cpp @@ -2,6 +2,8 @@ * @file llhost.cpp * @brief Encapsulates an IP address and a port. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llhost.h b/linden/indra/llmessage/llhost.h index 1d37639..e6f811a 100644 --- a/linden/indra/llmessage/llhost.h +++ b/linden/indra/llmessage/llhost.h @@ -3,6 +3,8 @@ * @brief a LLHost uniquely defines a host (Simulator, Proxy or other) * across the network * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLHOST_H diff --git a/linden/indra/llmessage/llhttpassetstorage.cpp b/linden/indra/llmessage/llhttpassetstorage.cpp index 924d903..c5b897b 100644 --- a/linden/indra/llmessage/llhttpassetstorage.cpp +++ b/linden/indra/llmessage/llhttpassetstorage.cpp @@ -3,6 +3,8 @@ * @brief Subclass capable of loading asset data to/from an external * source. Currently, a web server accessed via curl * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -336,15 +339,17 @@ size_t LLHTTPAssetRequest::readCompressedData(void* data, size_t size) while (mZStream.avail_out > 0) { - if (mZStream.avail_in == 0 && !mZInputExhausted) + if (mZStream.avail_in == 0 && !mZInputExhausted) { S32 to_read = llmin(COMPRESSED_INPUT_BUFFER_SIZE, (S32)(mVFile->getSize() - mVFile->tell())); - mVFile->read((U8*)mZInputBuffer, to_read); /*Flawfinder: ignore*/ - - mZStream.next_in = (Bytef*)mZInputBuffer; - mZStream.avail_in = mVFile->getLastBytesRead(); + if ( to_read > 0 ) + { + mVFile->read((U8*)mZInputBuffer, to_read); /*Flawfinder: ignore*/ + mZStream.next_in = (Bytef*)mZInputBuffer; + mZStream.avail_in = mVFile->getLastBytesRead(); + } mZInputExhausted = mZStream.avail_in == 0; } @@ -352,8 +357,13 @@ size_t LLHTTPAssetRequest::readCompressedData(void* data, size_t size) int r = deflate(&mZStream, mZInputExhausted ? Z_FINISH : Z_NO_FLUSH); - if (r == Z_STREAM_END) + if (r == Z_STREAM_END || r < 0 || mZInputExhausted) { + if (r < 0) + { + llwarns << "LLHTTPAssetRequest::readCompressedData: deflate returned error code " + << (S32) r << llendl; + } break; } } @@ -365,15 +375,20 @@ size_t LLHTTPAssetRequest::readCompressedData(void* data, size_t size) size_t LLHTTPAssetRequest::curlCompressedUploadCallback( void *data, size_t size, size_t nmemb, void *user_data) { - if (!gAssetStorage) + size_t num_read = 0; + + if (gAssetStorage) { - return 0; + CURL *curl_handle = (CURL *)user_data; + LLHTTPAssetRequest *req = NULL; + curl_easy_getinfo(curl_handle, CURLINFO_PRIVATE, &req); + if (req) + { + num_read = req->readCompressedData(data, size * nmemb); + } } - CURL *curl_handle = (CURL *)user_data; - LLHTTPAssetRequest *req = NULL; - curl_easy_getinfo(curl_handle, CURLINFO_PRIVATE, &req); - return req->readCompressedData(data, size * nmemb); + return num_read; } ///////////////////////////////////////////////////////////////////////////////// @@ -531,9 +546,8 @@ void LLHTTPAssetStorage::storeAssetData( { callback(LLUUID::null, user_data, LL_ERR_CANNOT_OPEN_FILE, LL_EXSTAT_BLOCKED_FILE); } + delete legacy; } - // Coverity CID-269 says there's a leak of 'legacy' here, but - // legacyStoreDataCallback() will delete it somewhere down the line. } // virtual diff --git a/linden/indra/llmessage/llhttpassetstorage.h b/linden/indra/llmessage/llhttpassetstorage.h index 7fee143..e6ec39e 100644 --- a/linden/indra/llmessage/llhttpassetstorage.h +++ b/linden/indra/llmessage/llhttpassetstorage.h @@ -2,6 +2,8 @@ * @file llhttpassetstorage.h * @brief Class for loading asset data to/from an external source over http. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLHTTPASSETSTORAGE_H diff --git a/linden/indra/llmessage/llhttpclient.cpp b/linden/indra/llmessage/llhttpclient.cpp index 4e844c3..7144f13 100644 --- a/linden/indra/llmessage/llhttpclient.cpp +++ b/linden/indra/llmessage/llhttpclient.cpp @@ -2,6 +2,8 @@ * @file llhttpclient.cpp * @brief Implementation of classes for making HTTP requests. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -74,7 +77,7 @@ void LLHTTPClient::Responder::completedRaw(U32 status, const std::string& reason LLBufferStream istr(channels, buffer.get()); LLSD content; - if (200 <= status && status < 300) + if (isGoodStatus(status)) { LLSDSerialize::fromXML(content, istr); /* @@ -93,7 +96,7 @@ void LLHTTPClient::Responder::completedRaw(U32 status, const std::string& reason // virtual void LLHTTPClient::Responder::completed(U32 status, const std::string& reason, const LLSD& content) { - if (200 <= status && status < 300) + if(isGoodStatus(status)) { result(content); } diff --git a/linden/indra/llmessage/llhttpclient.h b/linden/indra/llmessage/llhttpclient.h index 578b176..8c2309c 100644 --- a/linden/indra/llmessage/llhttpclient.h +++ b/linden/indra/llmessage/llhttpclient.h @@ -2,6 +2,8 @@ * @file llhttpclient.h * @brief Declaration of classes for making HTTP client requests. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLHTTPCLIENT_H @@ -57,6 +60,14 @@ public: Responder(); virtual ~Responder(); + /** + * @brief return true if the status code indicates success. + */ + static bool isGoodStatus(U32 status) + { + return((200 <= status) && (status < 300)); + } + virtual void error(U32 status, const std::string& reason); // called with bad status codes virtual void result(const LLSD& content); diff --git a/linden/indra/llmessage/llhttpnode.cpp b/linden/indra/llmessage/llhttpnode.cpp index 25413b4..1289b63 100644 --- a/linden/indra/llmessage/llhttpnode.cpp +++ b/linden/indra/llmessage/llhttpnode.cpp @@ -2,6 +2,8 @@ * @file llhttpnode.cpp * @brief Implementation of classes for generic HTTP/LSL/REST handling. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llhttpnode.h b/linden/indra/llmessage/llhttpnode.h index db82296..a283a26 100644 --- a/linden/indra/llmessage/llhttpnode.h +++ b/linden/indra/llmessage/llhttpnode.h @@ -2,6 +2,8 @@ * @file llhttpnode.h * @brief Declaration of classes for generic HTTP/LSL/REST handling. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLHTTPNODE_H diff --git a/linden/indra/llmessage/llhttpsender.cpp b/linden/indra/llmessage/llhttpsender.cpp index 3796a52..096bc73 100644 --- a/linden/indra/llmessage/llhttpsender.cpp +++ b/linden/indra/llmessage/llhttpsender.cpp @@ -2,7 +2,9 @@ * @file llhttpsender.cpp * @brief Abstracts details of sending messages via HTTP. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llhttpsender.h b/linden/indra/llmessage/llhttpsender.h index 5d8b028..3a6cd68 100644 --- a/linden/indra/llmessage/llhttpsender.h +++ b/linden/indra/llmessage/llhttpsender.h @@ -2,7 +2,9 @@ * @file llhttpsender.h * @brief Abstracts details of sending messages via HTTP. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_HTTP_SENDER_H diff --git a/linden/indra/llmessage/llinstantmessage.cpp b/linden/indra/llmessage/llinstantmessage.cpp index 0a3a1e6..04af44f 100644 --- a/linden/indra/llmessage/llinstantmessage.cpp +++ b/linden/indra/llmessage/llinstantmessage.cpp @@ -4,6 +4,8 @@ * @date 2005-08-29 * @brief Constants and functions used in IM. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llinstantmessage.h b/linden/indra/llmessage/llinstantmessage.h index 45db037..abb1651 100644 --- a/linden/indra/llmessage/llinstantmessage.h +++ b/linden/indra/llmessage/llinstantmessage.h @@ -2,6 +2,8 @@ * @file llinstantmessage.h * @brief Constants and declarations used by instant messages. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLINSTANTMESSAGE_H diff --git a/linden/indra/llmessage/llinvite.h b/linden/indra/llmessage/llinvite.h index d3774c4..e9439de 100644 --- a/linden/indra/llmessage/llinvite.h +++ b/linden/indra/llmessage/llinvite.h @@ -2,6 +2,8 @@ * @file llinvite.h * @brief Constants used for inviting users to join groups. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLINVITE_H diff --git a/linden/indra/llmessage/lliobuffer.cpp b/linden/indra/llmessage/lliobuffer.cpp index 7dea578..061e8f0 100644 --- a/linden/indra/llmessage/lliobuffer.cpp +++ b/linden/indra/llmessage/lliobuffer.cpp @@ -4,6 +4,8 @@ * @date 2005-05-04 * @brief Definition of buffer based implementations of IO Pipes. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/lliobuffer.h b/linden/indra/llmessage/lliobuffer.h index ac24576..14381ab 100644 --- a/linden/indra/llmessage/lliobuffer.h +++ b/linden/indra/llmessage/lliobuffer.h @@ -4,6 +4,8 @@ * @date 2005-05-04 * @brief Declaration of buffers for use in IO Pipes. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLIOBUFFER_H diff --git a/linden/indra/llmessage/lliohttpserver.cpp b/linden/indra/llmessage/lliohttpserver.cpp index 3c8010b..473eaea 100644 --- a/linden/indra/llmessage/lliohttpserver.cpp +++ b/linden/indra/llmessage/lliohttpserver.cpp @@ -4,6 +4,8 @@ * @date 2005-10-05 * @brief Implementation of the http server classes * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/lliohttpserver.h b/linden/indra/llmessage/lliohttpserver.h index 8a6c8d4..bf61dae 100644 --- a/linden/indra/llmessage/lliohttpserver.h +++ b/linden/indra/llmessage/lliohttpserver.h @@ -3,6 +3,8 @@ * @brief Declaration of function for creating an HTTP wire server * @see LLIOServerSocket, LLPumpIO * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLIOHTTPSERVER_H diff --git a/linden/indra/llmessage/lliopipe.cpp b/linden/indra/llmessage/lliopipe.cpp index a37b046..8c0d01f 100644 --- a/linden/indra/llmessage/lliopipe.cpp +++ b/linden/indra/llmessage/lliopipe.cpp @@ -4,6 +4,8 @@ * @date 2004-11-19 * @brief Implementation of the LLIOPipe class * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/lliopipe.h b/linden/indra/llmessage/lliopipe.h index 38a98a6..47924ee 100644 --- a/linden/indra/llmessage/lliopipe.h +++ b/linden/indra/llmessage/lliopipe.h @@ -4,6 +4,8 @@ * @date 2004-11-18 * @brief Declaration of base IO class * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLIOPIPE_H diff --git a/linden/indra/llmessage/lliosocket.cpp b/linden/indra/llmessage/lliosocket.cpp index fdb4a89..920a5e4 100644 --- a/linden/indra/llmessage/lliosocket.cpp +++ b/linden/indra/llmessage/lliosocket.cpp @@ -4,6 +4,8 @@ * @date 2005-07-31 * @brief Sockets declarations for use with the io pipes * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/lliosocket.h b/linden/indra/llmessage/lliosocket.h index 0f5eae8..586f489 100644 --- a/linden/indra/llmessage/lliosocket.h +++ b/linden/indra/llmessage/lliosocket.h @@ -4,6 +4,8 @@ * @date 2005-07-31 * @brief Declaration of files used for handling sockets and associated pipes * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLIOSOCKET_H diff --git a/linden/indra/llmessage/llioutil.cpp b/linden/indra/llmessage/llioutil.cpp index 21e36fa..b00ec87 100644 --- a/linden/indra/llmessage/llioutil.cpp +++ b/linden/indra/llmessage/llioutil.cpp @@ -4,6 +4,8 @@ * @date 2005-10-05 * @brief Utility functionality for the io pipes. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llioutil.h b/linden/indra/llmessage/llioutil.h index 27cd39a..e2f33a4 100644 --- a/linden/indra/llmessage/llioutil.h +++ b/linden/indra/llmessage/llioutil.h @@ -4,6 +4,8 @@ * @date 2005-10-05 * @brief Helper classes for dealing with IOPipes * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLIOUTIL_H diff --git a/linden/indra/llmessage/llloginflags.h b/linden/indra/llmessage/llloginflags.h index 7725419..ab8228b 100644 --- a/linden/indra/llmessage/llloginflags.h +++ b/linden/indra/llmessage/llloginflags.h @@ -2,6 +2,8 @@ * @file llloginflags.h * @brief Login flag constants. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLLOGINFLAGS_H diff --git a/linden/indra/llmessage/lllogtextmessage.cpp b/linden/indra/llmessage/lllogtextmessage.cpp index 06c88b9..5a02860 100644 --- a/linden/indra/llmessage/lllogtextmessage.cpp +++ b/linden/indra/llmessage/lllogtextmessage.cpp @@ -4,6 +4,8 @@ * @date 2005-01-12 * @brief Impelmentation of the text logger. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/lllogtextmessage.h b/linden/indra/llmessage/lllogtextmessage.h index 89fb90c..a0a1509 100644 --- a/linden/indra/llmessage/lllogtextmessage.h +++ b/linden/indra/llmessage/lllogtextmessage.h @@ -5,6 +5,8 @@ * @brief Declaration of class for coalescing text logs generated * from chat and IM * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -27,6 +29,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLLOGTEXTMESSAGE_H diff --git a/linden/indra/llmessage/llmail.cpp b/linden/indra/llmessage/llmail.cpp index 633a2a3..ac0ee66 100644 --- a/linden/indra/llmessage/llmail.cpp +++ b/linden/indra/llmessage/llmail.cpp @@ -2,6 +2,8 @@ * @file llmail.cpp * @brief smtp helper functions. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llmail.h b/linden/indra/llmessage/llmail.h index 26aaa3a..2a88592 100644 --- a/linden/indra/llmessage/llmail.h +++ b/linden/indra/llmessage/llmail.h @@ -2,6 +2,8 @@ * @file llmail.h * @brief smtp helper functions. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMAIL_H diff --git a/linden/indra/llmessage/llmessagebuilder.cpp b/linden/indra/llmessage/llmessagebuilder.cpp index 364e417..cd0b07e 100644 --- a/linden/indra/llmessage/llmessagebuilder.cpp +++ b/linden/indra/llmessage/llmessagebuilder.cpp @@ -2,6 +2,8 @@ * @file llmessagebuilder.cpp * @brief LLMessageBuilder class implementation * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llmessagebuilder.h b/linden/indra/llmessage/llmessagebuilder.h index 5c231bd..c478c45 100644 --- a/linden/indra/llmessage/llmessagebuilder.h +++ b/linden/indra/llmessage/llmessagebuilder.h @@ -2,7 +2,9 @@ * @file llmessagebuilder.h * @brief Declaration of LLMessageBuilder class. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMESSAGEBUILDER_H diff --git a/linden/indra/llmessage/llmessageconfig.cpp b/linden/indra/llmessage/llmessageconfig.cpp index a619e80..78e22dd 100644 --- a/linden/indra/llmessage/llmessageconfig.cpp +++ b/linden/indra/llmessage/llmessageconfig.cpp @@ -2,6 +2,8 @@ * @file llmessageconfig.cpp * @brief Live file handling for messaging * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -50,10 +53,10 @@ class LLMessageConfigFile : public LLLiveFile { public: LLMessageConfigFile() - : LLLiveFile(fileName(), messageConfigRefreshRate) + : LLLiveFile(filename(), messageConfigRefreshRate) { } - static std::string fileName(); + static std::string filename(); LLSD mMessages; std::string mServerDefault; @@ -72,7 +75,7 @@ public: LLSD mCapBans; }; -std::string LLMessageConfigFile::fileName() +std::string LLMessageConfigFile::filename() { std::ostringstream ostr; ostr << sConfigDir//gAppSimp->getOption("configdir").asString() @@ -93,9 +96,10 @@ void LLMessageConfigFile::loadFile() LLSD data; { llifstream file(filename().c_str()); + if (file.is_open()) { - llinfos << "Loading message.xml file at " << fileName() << llendl; + llinfos << "Loading message.xml file at " << filename() << llendl; LLSDSerialize::fromXML(data, file); } diff --git a/linden/indra/llmessage/llmessageconfig.h b/linden/indra/llmessage/llmessageconfig.h index 86e7fb0..eb3113b 100644 --- a/linden/indra/llmessage/llmessageconfig.h +++ b/linden/indra/llmessage/llmessageconfig.h @@ -2,6 +2,8 @@ * @file llmessageconfig.h * @brief Live file handling for messaging * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_MESSAGECONFIG_H diff --git a/linden/indra/llmessage/llmessagereader.cpp b/linden/indra/llmessage/llmessagereader.cpp index 2679019..7ec4f56 100644 --- a/linden/indra/llmessage/llmessagereader.cpp +++ b/linden/indra/llmessage/llmessagereader.cpp @@ -2,7 +2,9 @@ * @file llmessagereader.cpp * @brief LLMessageReader class implementation * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llmessagereader.h b/linden/indra/llmessage/llmessagereader.h index 9c1923a..4687191 100644 --- a/linden/indra/llmessage/llmessagereader.h +++ b/linden/indra/llmessage/llmessagereader.h @@ -2,7 +2,9 @@ * @file llmessagereader.h * @brief Declaration of LLMessageReader class. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMESSAGEREADER_H diff --git a/linden/indra/llmessage/llmessagetemplate.cpp b/linden/indra/llmessage/llmessagetemplate.cpp index daf7f7a..b6c5304 100644 --- a/linden/indra/llmessage/llmessagetemplate.cpp +++ b/linden/indra/llmessage/llmessagetemplate.cpp @@ -2,7 +2,9 @@ * @file llmessagetemplate.cpp * @brief Implementation of message template classes. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llmessagetemplate.h b/linden/indra/llmessage/llmessagetemplate.h index 804c343..5821474 100644 --- a/linden/indra/llmessage/llmessagetemplate.h +++ b/linden/indra/llmessage/llmessagetemplate.h @@ -2,7 +2,9 @@ * @file llmessagetemplate.h * @brief Declaration of the message template classes. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMESSAGETEMPLATE_H diff --git a/linden/indra/llmessage/llmessagetemplateparser.cpp b/linden/indra/llmessage/llmessagetemplateparser.cpp index 4c14ede..e8843c7 100644 --- a/linden/indra/llmessage/llmessagetemplateparser.cpp +++ b/linden/indra/llmessage/llmessagetemplateparser.cpp @@ -2,7 +2,9 @@ * @file llmessagetemplateparser.cpp * @brief LLMessageTemplateParser implementation * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llmessagetemplateparser.h b/linden/indra/llmessage/llmessagetemplateparser.h index f56dfec..9a71184 100644 --- a/linden/indra/llmessage/llmessagetemplateparser.h +++ b/linden/indra/llmessage/llmessagetemplateparser.h @@ -2,6 +2,8 @@ * @file llmessagetemplateparser.h * @brief Classes to parse message template. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_MESSAGETEMPLATEPARSER_H diff --git a/linden/indra/llmessage/llmessagethrottle.cpp b/linden/indra/llmessage/llmessagethrottle.cpp index bbaa9d8..c45feb2 100644 --- a/linden/indra/llmessage/llmessagethrottle.cpp +++ b/linden/indra/llmessage/llmessagethrottle.cpp @@ -2,6 +2,8 @@ * @file llmessagethrottle.cpp * @brief LLMessageThrottle class used for throttling messages. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llmessagethrottle.h b/linden/indra/llmessage/llmessagethrottle.h index 522358c..b43b5a0 100644 --- a/linden/indra/llmessage/llmessagethrottle.h +++ b/linden/indra/llmessage/llmessagethrottle.h @@ -2,6 +2,8 @@ * @file llmessagethrottle.h * @brief LLMessageThrottle class used for throttling messages. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMESSAGETHROTTLE_H diff --git a/linden/indra/llmessage/llmime.cpp b/linden/indra/llmessage/llmime.cpp index 6938ed7..7d43f38 100644 --- a/linden/indra/llmessage/llmime.cpp +++ b/linden/indra/llmessage/llmime.cpp @@ -4,6 +4,8 @@ * @date 2006-12-20 * @brief Implementation of mime tools. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llmime.h b/linden/indra/llmessage/llmime.h index 307a33d..0a7fa1d 100644 --- a/linden/indra/llmessage/llmime.h +++ b/linden/indra/llmessage/llmime.h @@ -4,6 +4,8 @@ * @date 2006-12-20 * @brief Declaration of mime tools. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMIME_H diff --git a/linden/indra/llmessage/llmsgvariabletype.h b/linden/indra/llmessage/llmsgvariabletype.h index 59fba7c..5ce171b 100644 --- a/linden/indra/llmessage/llmsgvariabletype.h +++ b/linden/indra/llmessage/llmsgvariabletype.h @@ -2,7 +2,9 @@ * @file llmsgvariabletype.h * @brief Declaration of the EMsgVariableType enumeration. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMSGVARIABLETYPE_H diff --git a/linden/indra/llmessage/llnamevalue.cpp b/linden/indra/llmessage/llnamevalue.cpp index a11bf97..932eeaa 100644 --- a/linden/indra/llmessage/llnamevalue.cpp +++ b/linden/indra/llmessage/llnamevalue.cpp @@ -2,6 +2,8 @@ * @file llnamevalue.cpp * @brief class for defining name value pairs. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Examples: diff --git a/linden/indra/llmessage/llnamevalue.h b/linden/indra/llmessage/llnamevalue.h index 580c99d..1bdfeb2 100644 --- a/linden/indra/llmessage/llnamevalue.h +++ b/linden/indra/llmessage/llnamevalue.h @@ -2,6 +2,8 @@ * @file llnamevalue.h * @brief class for defining name value pairs. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,18 +26,15 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLNAMEVALUE_H #define LL_LLNAMEVALUE_H -#include -#include - #include "string_table.h" #include "llskipmap.h" #include "llmath.h" -//#include "vmath.h" #include "v3math.h" #include "lldbstrings.h" diff --git a/linden/indra/llmessage/llnullcipher.cpp b/linden/indra/llmessage/llnullcipher.cpp index eddadeb..613e764 100644 --- a/linden/indra/llmessage/llnullcipher.cpp +++ b/linden/indra/llmessage/llnullcipher.cpp @@ -2,6 +2,8 @@ * @file llnullcipher.cpp * @brief Implementation of a cipher which does not encrypt. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llnullcipher.h b/linden/indra/llmessage/llnullcipher.h index 2e41063..a6dec02 100644 --- a/linden/indra/llmessage/llnullcipher.h +++ b/linden/indra/llmessage/llnullcipher.h @@ -1,6 +1,8 @@ /** * @file llnullcipher.h * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLNULLCIPHER_H diff --git a/linden/indra/llmessage/llpacketack.cpp b/linden/indra/llmessage/llpacketack.cpp index 27d9916..dbc7865 100644 --- a/linden/indra/llmessage/llpacketack.cpp +++ b/linden/indra/llmessage/llpacketack.cpp @@ -4,7 +4,9 @@ * @date 2007-05-09 * @brief Implementation of the LLReliablePacket. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llpacketack.h b/linden/indra/llmessage/llpacketack.h index 33fb5a0..a5b425c 100644 --- a/linden/indra/llmessage/llpacketack.h +++ b/linden/indra/llmessage/llpacketack.h @@ -2,6 +2,8 @@ * @file llpacketack.h * @brief Reliable UDP helpers for the message system. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPACKETACK_H diff --git a/linden/indra/llmessage/llpacketbuffer.cpp b/linden/indra/llmessage/llpacketbuffer.cpp index 525569d..cb71fcd 100644 --- a/linden/indra/llmessage/llpacketbuffer.cpp +++ b/linden/indra/llmessage/llpacketbuffer.cpp @@ -2,6 +2,8 @@ * @file llpacketbuffer.cpp * @brief implementation of LLPacketBuffer class for a packet. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llpacketbuffer.h b/linden/indra/llmessage/llpacketbuffer.h index 17fe446..1e57517 100644 --- a/linden/indra/llmessage/llpacketbuffer.h +++ b/linden/indra/llmessage/llpacketbuffer.h @@ -3,6 +3,8 @@ * @brief definition of LLPacketBuffer class for implementing a * resend, drop, or delay in packet transmissions. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPACKETBUFFER_H diff --git a/linden/indra/llmessage/llpacketring.cpp b/linden/indra/llmessage/llpacketring.cpp index e07c754..48a02fe 100644 --- a/linden/indra/llmessage/llpacketring.cpp +++ b/linden/indra/llmessage/llpacketring.cpp @@ -2,6 +2,8 @@ * @file llpacketring.cpp * @brief implementation of LLPacketRing class for a packet. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llpacketring.h b/linden/indra/llmessage/llpacketring.h index 1a0c0c6..109d5e6 100644 --- a/linden/indra/llmessage/llpacketring.h +++ b/linden/indra/llmessage/llpacketring.h @@ -3,6 +3,8 @@ * @brief definition of LLPacketRing class for implementing a resend, * drop, or delay in packet transmissions * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPACKETRING_H diff --git a/linden/indra/llmessage/llpartdata.cpp b/linden/indra/llmessage/llpartdata.cpp index f46481e..0e1dc4a 100644 --- a/linden/indra/llmessage/llpartdata.cpp +++ b/linden/indra/llmessage/llpartdata.cpp @@ -2,6 +2,8 @@ * @file llpartdata.cpp * @brief Particle system data packing * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llpartdata.h b/linden/indra/llmessage/llpartdata.h index 3177e84..4220f5d 100644 --- a/linden/indra/llmessage/llpartdata.h +++ b/linden/indra/llmessage/llpartdata.h @@ -2,6 +2,8 @@ * @file llpartdata.h * @brief Particle system data packing * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,13 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPARTDATA_H #define LL_LLPARTDATA_H -#include - #include "lluuid.h" #include "v3math.h" #include "v3dmath.h" diff --git a/linden/indra/llmessage/llpumpio.cpp b/linden/indra/llmessage/llpumpio.cpp index e76f3ea..ea7c06f 100644 --- a/linden/indra/llmessage/llpumpio.cpp +++ b/linden/indra/llmessage/llpumpio.cpp @@ -4,6 +4,8 @@ * @date 2004-11-21 * @brief Implementation of the i/o pump and related functions. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -684,8 +687,9 @@ void LLPumpIO::initialize(apr_pool_t* pool) LLMemType m1(LLMemType::MTYPE_IO_PUMP); if(!pool) return; #if LL_THREADS_APR - apr_thread_mutex_create(&mChainsMutex, APR_THREAD_MUTEX_DEFAULT, pool); - apr_thread_mutex_create(&mCallbackMutex, APR_THREAD_MUTEX_DEFAULT, pool); + // SJB: Windows defaults to NESTED and OSX defaults to UNNESTED, so use UNNESTED explicitly. + apr_thread_mutex_create(&mChainsMutex, APR_THREAD_MUTEX_UNNESTED, pool); + apr_thread_mutex_create(&mCallbackMutex, APR_THREAD_MUTEX_UNNESTED, pool); #endif mPool = pool; } diff --git a/linden/indra/llmessage/llpumpio.h b/linden/indra/llmessage/llpumpio.h index 0f2bd48..4d865a8 100644 --- a/linden/indra/llmessage/llpumpio.h +++ b/linden/indra/llmessage/llpumpio.h @@ -4,6 +4,8 @@ * @date 2004-11-19 * @brief Declaration of pump class which manages io chains. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPUMPIO_H diff --git a/linden/indra/llmessage/llqueryflags.h b/linden/indra/llmessage/llqueryflags.h index 9143995..9b3074e 100644 --- a/linden/indra/llmessage/llqueryflags.h +++ b/linden/indra/llmessage/llqueryflags.h @@ -2,6 +2,8 @@ * @file llqueryflags.h * @brief Flags for directory queries * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLQUERYFLAGS_H diff --git a/linden/indra/llmessage/llregionflags.h b/linden/indra/llmessage/llregionflags.h index 8702277..72272c0 100644 --- a/linden/indra/llmessage/llregionflags.h +++ b/linden/indra/llmessage/llregionflags.h @@ -2,6 +2,8 @@ * @file llregionflags.h * @brief Flags that are sent in the statistics message region_flags field. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLREGIONFLAGS_H @@ -90,6 +93,8 @@ const U32 REGION_FLAGS_ABUSE_EMAIL_TO_ESTATE_OWNER = (1 << 27); const U32 REGION_FLAGS_ALLOW_VOICE = (1 << 28); +const U32 REGION_FLAGS_BLOCK_PARCEL_SEARCH = (1 << 29); + const U32 REGION_FLAGS_DEFAULT = REGION_FLAGS_ALLOW_LANDMARK | REGION_FLAGS_ALLOW_SET_HOME | @@ -179,3 +184,4 @@ const U32 SWD_SCRIPTED_ONLY = (1 << 2); #endif + diff --git a/linden/indra/llmessage/llregionhandle.h b/linden/indra/llmessage/llregionhandle.h index ad4cf61..d9fcd82 100644 --- a/linden/indra/llmessage/llregionhandle.h +++ b/linden/indra/llmessage/llregionhandle.h @@ -2,6 +2,8 @@ * @file llregionhandle.h * @brief Routines for converting positions to/from region handles. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,13 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLREGIONHANDLE_H #define LL_LLREGIONHANDLE_H -#include - #include "indra_constants.h" #include "v3math.h" #include "v3dmath.h" diff --git a/linden/indra/llmessage/llsdappservices.cpp b/linden/indra/llmessage/llsdappservices.cpp index ae1505b..88588df 100644 --- a/linden/indra/llmessage/llsdappservices.cpp +++ b/linden/indra/llmessage/llsdappservices.cpp @@ -3,6 +3,8 @@ * @author Phoenix * @date 2006-09-12 * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llsdappservices.h b/linden/indra/llmessage/llsdappservices.h index 0075b2e..089687b 100644 --- a/linden/indra/llmessage/llsdappservices.h +++ b/linden/indra/llmessage/llsdappservices.h @@ -4,6 +4,8 @@ * @date 2006-09-12 * @brief Header file to declare the /app common web services. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSDAPPSERVICES_H diff --git a/linden/indra/llmessage/llsdhttpserver.cpp b/linden/indra/llmessage/llsdhttpserver.cpp index 8ca7f14..41bc503 100644 --- a/linden/indra/llmessage/llsdhttpserver.cpp +++ b/linden/indra/llmessage/llsdhttpserver.cpp @@ -2,6 +2,8 @@ * @file llsdhttpserver.cpp * @brief Standard LLSD services * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llsdhttpserver.h b/linden/indra/llmessage/llsdhttpserver.h index b6904f3..e0e8853 100644 --- a/linden/indra/llmessage/llsdhttpserver.h +++ b/linden/indra/llmessage/llsdhttpserver.h @@ -2,6 +2,8 @@ * @file llsdhttpserver.h * @brief Standard LLSD services * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSDHTTPSERVER_H diff --git a/linden/indra/llmessage/llsdmessagebuilder.cpp b/linden/indra/llmessage/llsdmessagebuilder.cpp index f8fb30e..43fe7d6 100755 --- a/linden/indra/llmessage/llsdmessagebuilder.cpp +++ b/linden/indra/llmessage/llsdmessagebuilder.cpp @@ -2,7 +2,9 @@ * @file llsdmessagebuilder.cpp * @brief LLSDMessageBuilder class implementation. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llsdmessagebuilder.h b/linden/indra/llmessage/llsdmessagebuilder.h index 8ea7763..4cdae36 100755 --- a/linden/indra/llmessage/llsdmessagebuilder.h +++ b/linden/indra/llmessage/llsdmessagebuilder.h @@ -2,7 +2,9 @@ * @file llsdmessagebuilder.h * @brief Declaration of LLSDMessageBuilder class. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSDMESSAGEBUILDER_H diff --git a/linden/indra/llmessage/llsdmessagereader.cpp b/linden/indra/llmessage/llsdmessagereader.cpp index 6742edb..e69c3e3 100755 --- a/linden/indra/llmessage/llsdmessagereader.cpp +++ b/linden/indra/llmessage/llsdmessagereader.cpp @@ -2,7 +2,9 @@ * @file llsdmessagereader.cpp * @brief LLSDMessageReader class implementation. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llsdmessagereader.h b/linden/indra/llmessage/llsdmessagereader.h index d6d9f3d..66ac1d1 100755 --- a/linden/indra/llmessage/llsdmessagereader.h +++ b/linden/indra/llmessage/llsdmessagereader.h @@ -1,3 +1,34 @@ +/** + * @file llsdmessagereader.h + * @brief LLSDMessageReader class Declaration + * + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. + * + * Second Life Viewer Source Code + * The source code in this file ("Source Code") is provided by Linden Lab + * to you under the terms of the GNU General Public License, version 2.0 + * ("GPL"), unless you have obtained a separate licensing agreement + * ("Other License"), formally executed by you and Linden Lab. Terms of + * the GPL can be found in doc/GPL-license.txt in this distribution, or + * online at http://secondlife.com/developers/opensource/gplv2 + * + * There are special exceptions to the terms and conditions of the GPL as + * it is applied to this Source Code. View the full text of the exception + * in the file doc/FLOSS-exception.txt in this software distribution, or + * online at http://secondlife.com/developers/opensource/flossexception + * + * By copying, modifying or distributing this software, you acknowledge + * that you have read and understood your obligations described above, + * and agree to abide by those obligations. + * + * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO + * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, + * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ + */ + #ifndef LL_LLSDMESSAGEREADER_H #define LL_LLSDMESSAGEREADER_H diff --git a/linden/indra/llmessage/llsdrpcclient.cpp b/linden/indra/llmessage/llsdrpcclient.cpp index 64d4b98..0a12c47 100644 --- a/linden/indra/llmessage/llsdrpcclient.cpp +++ b/linden/indra/llmessage/llsdrpcclient.cpp @@ -4,6 +4,8 @@ * @date 2005-11-05 * @brief Implementation of the llsd client classes. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llsdrpcclient.h b/linden/indra/llmessage/llsdrpcclient.h index 52439b9..4511d10 100644 --- a/linden/indra/llmessage/llsdrpcclient.h +++ b/linden/indra/llmessage/llsdrpcclient.h @@ -4,6 +4,8 @@ * @date 2005-11-05 * @brief Implementation and helpers for structure data RPC clients. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSDRPCCLIENT_H diff --git a/linden/indra/llmessage/llsdrpcserver.cpp b/linden/indra/llmessage/llsdrpcserver.cpp index ed37181..13ed791 100644 --- a/linden/indra/llmessage/llsdrpcserver.cpp +++ b/linden/indra/llmessage/llsdrpcserver.cpp @@ -4,6 +4,8 @@ * @date 2005-10-11 * @brief Implementation of the LLSDRPCServer and related classes. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llsdrpcserver.h b/linden/indra/llmessage/llsdrpcserver.h index 4007d6e..92992aa 100644 --- a/linden/indra/llmessage/llsdrpcserver.h +++ b/linden/indra/llmessage/llsdrpcserver.h @@ -4,6 +4,8 @@ * @date 2005-10-11 * @brief Declaration of the structured data remote procedure call server. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSDRPCSERVER_H diff --git a/linden/indra/llmessage/llservice.cpp b/linden/indra/llmessage/llservice.cpp index 052524d..daa21b1 100644 --- a/linden/indra/llmessage/llservice.cpp +++ b/linden/indra/llmessage/llservice.cpp @@ -3,6 +3,8 @@ * @author Phoenix * @date 2005-04-20 * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llservice.h b/linden/indra/llmessage/llservice.h index 5744f75..254b2d5 100644 --- a/linden/indra/llmessage/llservice.h +++ b/linden/indra/llmessage/llservice.h @@ -4,6 +4,8 @@ * @date 2004-11-21 * @brief Declaration file for LLService and related classes. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSERVICE_H diff --git a/linden/indra/llmessage/llservicebuilder.cpp b/linden/indra/llmessage/llservicebuilder.cpp index 0b35a69..4fb3530 100644 --- a/linden/indra/llmessage/llservicebuilder.cpp +++ b/linden/indra/llmessage/llservicebuilder.cpp @@ -2,28 +2,31 @@ * @file llservicebuilder.cpp * @brief Implementation of the LLServiceBuilder class. * -* Copyright (c) 2007-2007, Linden Research, Inc. +* $LicenseInfo:firstyear=2007&license=viewergpl$ * - * Second Life Viewer Source Code - * The source code in this file ("Source Code") is provided by Linden Lab - * to you under the terms of the GNU General Public License, version 2.0 - * ("GPL"), unless you have obtained a separate licensing agreement - * ("Other License"), formally executed by you and Linden Lab. Terms of - * the GPL can be found in doc/GPL-license.txt in this distribution, or - * online at http://secondlife.com/developers/opensource/gplv2 - * - * There are special exceptions to the terms and conditions of the GPL as - * it is applied to this Source Code. View the full text of the exception - * in the file doc/FLOSS-exception.txt in this software distribution, or - * online at http://secondlife.com/developers/opensource/flossexception - * - * By copying, modifying or distributing this software, you acknowledge - * that you have read and understood your obligations described above, - * and agree to abide by those obligations. - * - * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO - * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, - * COMPLETENESS OR PERFORMANCE. +* Copyright (c) 2007, Linden Research, Inc. +* +* Second Life Viewer Source Code +* The source code in this file ("Source Code") is provided by Linden Lab +* to you under the terms of the GNU General Public License, version 2.0 +* ("GPL"), unless you have obtained a separate licensing agreement +* ("Other License"), formally executed by you and Linden Lab. Terms of +* the GPL can be found in doc/GPL-license.txt in this distribution, or +* online at http://secondlife.com/developers/opensource/gplv2 +* +* There are special exceptions to the terms and conditions of the GPL as +* it is applied to this Source Code. View the full text of the exception +* in the file doc/FLOSS-exception.txt in this software distribution, or +* online at http://secondlife.com/developers/opensource/flossexception +* +* By copying, modifying or distributing this software, you acknowledge +* that you have read and understood your obligations described above, +* and agree to abide by those obligations. +* +* ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO +* WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, +* COMPLETENESS OR PERFORMANCE. +* $/LicenseInfo$ */ #include "linden_common.h" @@ -138,16 +141,19 @@ std::string LLServiceBuilder::buildServiceURI( { std::string query_str = LLURI::mapToQueryString( (*option_itr).second); - if(!query_str.empty()) - { - service_url.replace( - find_pos, - variable_name.length(), - query_str); - } + service_url.replace( + find_pos, + variable_name.length(), + query_str); } } } + if (service_url.find('{') != std::string::npos) + { + llwarns << "Constructed a likely bogus service URL: " << service_url + << llendl; + } + return service_url; } diff --git a/linden/indra/llmessage/llservicebuilder.h b/linden/indra/llmessage/llservicebuilder.h index 817ea0c..2c00660 100644 --- a/linden/indra/llmessage/llservicebuilder.h +++ b/linden/indra/llmessage/llservicebuilder.h @@ -2,28 +2,31 @@ * @file llservicebuilder.h * @brief Declaration of the LLServiceBuilder class. * -* Copyright (c) 2007-2007, Linden Research, Inc. +* $LicenseInfo:firstyear=2007&license=viewergpl$ * - * Second Life Viewer Source Code - * The source code in this file ("Source Code") is provided by Linden Lab - * to you under the terms of the GNU General Public License, version 2.0 - * ("GPL"), unless you have obtained a separate licensing agreement - * ("Other License"), formally executed by you and Linden Lab. Terms of - * the GPL can be found in doc/GPL-license.txt in this distribution, or - * online at http://secondlife.com/developers/opensource/gplv2 - * - * There are special exceptions to the terms and conditions of the GPL as - * it is applied to this Source Code. View the full text of the exception - * in the file doc/FLOSS-exception.txt in this software distribution, or - * online at http://secondlife.com/developers/opensource/flossexception - * - * By copying, modifying or distributing this software, you acknowledge - * that you have read and understood your obligations described above, - * and agree to abide by those obligations. - * - * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO - * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, - * COMPLETENESS OR PERFORMANCE. +* Copyright (c) 2007, Linden Research, Inc. +* +* Second Life Viewer Source Code +* The source code in this file ("Source Code") is provided by Linden Lab +* to you under the terms of the GNU General Public License, version 2.0 +* ("GPL"), unless you have obtained a separate licensing agreement +* ("Other License"), formally executed by you and Linden Lab. Terms of +* the GPL can be found in doc/GPL-license.txt in this distribution, or +* online at http://secondlife.com/developers/opensource/gplv2 +* +* There are special exceptions to the terms and conditions of the GPL as +* it is applied to this Source Code. View the full text of the exception +* in the file doc/FLOSS-exception.txt in this software distribution, or +* online at http://secondlife.com/developers/opensource/flossexception +* +* By copying, modifying or distributing this software, you acknowledge +* that you have read and understood your obligations described above, +* and agree to abide by those obligations. +* +* ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO +* WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, +* COMPLETENESS OR PERFORMANCE. +* $/LicenseInfo$ */ #ifndef LLSERVICEBUILDER_H diff --git a/linden/indra/llmessage/lltaskname.h b/linden/indra/llmessage/lltaskname.h index ac4fbd5..d5bcfbd 100644 --- a/linden/indra/llmessage/lltaskname.h +++ b/linden/indra/llmessage/lltaskname.h @@ -3,6 +3,8 @@ * @brief This contains the current list of valid tasks and is inluded * into both simulator and viewer * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTASKNAME_H diff --git a/linden/indra/llmessage/llteleportflags.h b/linden/indra/llmessage/llteleportflags.h index a40b081..c08c905 100644 --- a/linden/indra/llmessage/llteleportflags.h +++ b/linden/indra/llmessage/llteleportflags.h @@ -2,6 +2,8 @@ * @file llteleportflags.h * @brief Teleport flags * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTELEPORTFLAGS_H diff --git a/linden/indra/llmessage/lltemplatemessagebuilder.cpp b/linden/indra/llmessage/lltemplatemessagebuilder.cpp index 9473343..70c306c 100644 --- a/linden/indra/llmessage/lltemplatemessagebuilder.cpp +++ b/linden/indra/llmessage/lltemplatemessagebuilder.cpp @@ -2,7 +2,9 @@ * @file lltemplatemessagebuilder.cpp * @brief LLTemplateMessageBuilder class implementation. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/lltemplatemessagebuilder.h b/linden/indra/llmessage/lltemplatemessagebuilder.h index 40a2f0d..af4657c 100644 --- a/linden/indra/llmessage/lltemplatemessagebuilder.h +++ b/linden/indra/llmessage/lltemplatemessagebuilder.h @@ -2,7 +2,9 @@ * @file lltemplatemessagebuilder.h * @brief Declaration of LLTemplateMessageBuilder class. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTEMPLATEMESSAGEBUILDER_H diff --git a/linden/indra/llmessage/lltemplatemessagereader.cpp b/linden/indra/llmessage/lltemplatemessagereader.cpp index 4cde483..114c312 100644 --- a/linden/indra/llmessage/lltemplatemessagereader.cpp +++ b/linden/indra/llmessage/lltemplatemessagereader.cpp @@ -2,7 +2,9 @@ * @file lltemplatemessagereader.cpp * @brief LLTemplateMessageReader class implementation. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/lltemplatemessagereader.h b/linden/indra/llmessage/lltemplatemessagereader.h index 687b75b..42cd90e 100644 --- a/linden/indra/llmessage/lltemplatemessagereader.h +++ b/linden/indra/llmessage/lltemplatemessagereader.h @@ -2,7 +2,9 @@ * @file lltemplatemessagereader.h * @brief Declaration of LLTemplateMessageReader class. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTEMPLATEMESSAGEREADER_H diff --git a/linden/indra/llmessage/llthrottle.cpp b/linden/indra/llmessage/llthrottle.cpp index de80dd0..c6a819b 100644 --- a/linden/indra/llmessage/llthrottle.cpp +++ b/linden/indra/llmessage/llthrottle.cpp @@ -2,6 +2,8 @@ * @file llthrottle.cpp * @brief LLThrottle class used for network bandwidth control. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llthrottle.h b/linden/indra/llmessage/llthrottle.h index a87834b..a999510 100644 --- a/linden/indra/llmessage/llthrottle.h +++ b/linden/indra/llmessage/llthrottle.h @@ -2,6 +2,8 @@ * @file llthrottle.h * @brief LLThrottle class used for network bandwidth control * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTHROTTLE_H diff --git a/linden/indra/llmessage/lltransfermanager.cpp b/linden/indra/llmessage/lltransfermanager.cpp index 3de08c6..e80bc8c 100644 --- a/linden/indra/llmessage/lltransfermanager.cpp +++ b/linden/indra/llmessage/lltransfermanager.cpp @@ -3,6 +3,8 @@ * @brief Improved transfer mechanism for moving data through the * message system. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/lltransfermanager.h b/linden/indra/llmessage/lltransfermanager.h index d063156..1813dd0 100644 --- a/linden/indra/llmessage/lltransfermanager.h +++ b/linden/indra/llmessage/lltransfermanager.h @@ -3,6 +3,8 @@ * @brief Improved transfer mechanism for moving data through the * message system. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTRANSFERMANAGER_H diff --git a/linden/indra/llmessage/lltransfersourceasset.cpp b/linden/indra/llmessage/lltransfersourceasset.cpp index cfc7561..941c77e 100644 --- a/linden/indra/llmessage/lltransfersourceasset.cpp +++ b/linden/indra/llmessage/lltransfersourceasset.cpp @@ -2,6 +2,8 @@ * @file lltransfersourceasset.cpp * @brief Transfer system for sending an asset. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/lltransfersourceasset.h b/linden/indra/llmessage/lltransfersourceasset.h index b953f78..4a15d5e 100644 --- a/linden/indra/llmessage/lltransfersourceasset.h +++ b/linden/indra/llmessage/lltransfersourceasset.h @@ -2,6 +2,8 @@ * @file lltransfersourceasset.h * @brief Transfer system for sending an asset. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTRANSFERSOURCEASSET_H diff --git a/linden/indra/llmessage/lltransfersourcefile.cpp b/linden/indra/llmessage/lltransfersourcefile.cpp index 392349e..abbef1c 100644 --- a/linden/indra/llmessage/lltransfersourcefile.cpp +++ b/linden/indra/llmessage/lltransfersourcefile.cpp @@ -2,6 +2,8 @@ * @file lltransfersourcefile.cpp * @brief Transfer system for sending a file. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/lltransfersourcefile.h b/linden/indra/llmessage/lltransfersourcefile.h index 21661b5..c3523b1 100644 --- a/linden/indra/llmessage/lltransfersourcefile.h +++ b/linden/indra/llmessage/lltransfersourcefile.h @@ -2,6 +2,8 @@ * @file lltransfersourcefile.h * @brief Transfer system for sending a file. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTRANSFERSOURCEFILE_H @@ -31,8 +34,6 @@ #include "lltransfermanager.h" -#include - class LLTransferSourceParamsFile : public LLTransferSourceParams { public: diff --git a/linden/indra/llmessage/lltransfertargetfile.cpp b/linden/indra/llmessage/lltransfertargetfile.cpp index 00af3ff..d05f808 100644 --- a/linden/indra/llmessage/lltransfertargetfile.cpp +++ b/linden/indra/llmessage/lltransfertargetfile.cpp @@ -2,6 +2,8 @@ * @file lltransfertargetfile.cpp * @brief Transfer system for receiving a file. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/lltransfertargetfile.h b/linden/indra/llmessage/lltransfertargetfile.h index 50d617f..18b44e2 100644 --- a/linden/indra/llmessage/lltransfertargetfile.h +++ b/linden/indra/llmessage/lltransfertargetfile.h @@ -2,6 +2,8 @@ * @file lltransfertargetfile.h * @brief Transfer system for receiving a file. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTRANSFERTARGETFILE_H @@ -31,15 +34,13 @@ #include "lltransfermanager.h" -#include - typedef void (*LLTTFCompleteCallback)(const LLTSCode status, void *user_data); class LLTransferTargetParamsFile : public LLTransferTargetParams { public: LLTransferTargetParamsFile() : LLTransferTargetParams(LLTTT_FILE) {} - void setFilename(const char *filename) { mFilename = filename; } + void setFilename(const LLString& filename) { mFilename = filename; } void setCallback(LLTTFCompleteCallback cb, void *user_data) { mCompleteCallback = cb; mUserData = user_data; } friend class LLTransferTargetFile; diff --git a/linden/indra/llmessage/lltransfertargetvfile.cpp b/linden/indra/llmessage/lltransfertargetvfile.cpp index 6f2252d..4be0b65 100644 --- a/linden/indra/llmessage/lltransfertargetvfile.cpp +++ b/linden/indra/llmessage/lltransfertargetvfile.cpp @@ -2,6 +2,8 @@ * @file lltransfertargetvfile.cpp * @brief Transfer system for receiving a vfile. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/lltransfertargetvfile.h b/linden/indra/llmessage/lltransfertargetvfile.h index 98fcbc9..041b7ea 100644 --- a/linden/indra/llmessage/lltransfertargetvfile.h +++ b/linden/indra/llmessage/lltransfertargetvfile.h @@ -2,6 +2,8 @@ * @file lltransfertargetvfile.h * @brief Transfer system for receiving a vfile. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTRANSFERTARGETVFILE_H diff --git a/linden/indra/llmessage/llurlrequest.cpp b/linden/indra/llmessage/llurlrequest.cpp index 00c0577..857f804 100644 --- a/linden/indra/llmessage/llurlrequest.cpp +++ b/linden/indra/llmessage/llurlrequest.cpp @@ -4,6 +4,8 @@ * @date 2005-04-28 * @brief Implementation of the URLRequest class and related classes. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llurlrequest.h b/linden/indra/llmessage/llurlrequest.h index 8aa1788..f335316 100644 --- a/linden/indra/llmessage/llurlrequest.h +++ b/linden/indra/llmessage/llurlrequest.h @@ -4,6 +4,8 @@ * @date 2005-04-21 * @brief Declaration of url based requests on pipes. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLURLREQUEST_H diff --git a/linden/indra/llmessage/lluseroperation.cpp b/linden/indra/llmessage/lluseroperation.cpp index f43e02a..9ba70cc 100644 --- a/linden/indra/llmessage/lluseroperation.cpp +++ b/linden/indra/llmessage/lluseroperation.cpp @@ -2,6 +2,8 @@ * @file lluseroperation.cpp * @brief LLUserOperation class definition. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/lluseroperation.h b/linden/indra/llmessage/lluseroperation.h index 6ac2862..5006809 100644 --- a/linden/indra/llmessage/lluseroperation.h +++ b/linden/indra/llmessage/lluseroperation.h @@ -3,6 +3,8 @@ * @brief LLUserOperation class header file - used for message based * transaction. For example, L$ transactions. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLUSEROPERATION_H diff --git a/linden/indra/llmessage/llvehicleparams.h b/linden/indra/llmessage/llvehicleparams.h index 946f88c..bfc2a4a 100644 --- a/linden/indra/llmessage/llvehicleparams.h +++ b/linden/indra/llmessage/llvehicleparams.h @@ -3,6 +3,8 @@ * @brief For parameter names that must be shared between the * scripting language and the LLVehicleAction class on the simulator. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_VEHICLE_PARAMS_H diff --git a/linden/indra/llmessage/llxfer.cpp b/linden/indra/llmessage/llxfer.cpp index 4647980..fefb6f9 100644 --- a/linden/indra/llmessage/llxfer.cpp +++ b/linden/indra/llmessage/llxfer.cpp @@ -2,6 +2,8 @@ * @file llxfer.cpp * @brief implementation of LLXfer class for a single xfer. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llxfer.h b/linden/indra/llmessage/llxfer.h index de93dba..017a521 100644 --- a/linden/indra/llmessage/llxfer.h +++ b/linden/indra/llmessage/llxfer.h @@ -2,6 +2,8 @@ * @file llxfer.h * @brief definition of LLXfer class for a single xfer * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLXFER_H diff --git a/linden/indra/llmessage/llxfer_file.cpp b/linden/indra/llmessage/llxfer_file.cpp index 7478316..caa418e 100644 --- a/linden/indra/llmessage/llxfer_file.cpp +++ b/linden/indra/llmessage/llxfer_file.cpp @@ -2,6 +2,8 @@ * @file llxfer_file.cpp * @brief implementation of LLXfer_File class for a single xfer (file) * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llxfer_file.h b/linden/indra/llmessage/llxfer_file.h index 4d34acb..b87417d 100644 --- a/linden/indra/llmessage/llxfer_file.h +++ b/linden/indra/llmessage/llxfer_file.h @@ -2,6 +2,8 @@ * @file llxfer_file.h * @brief definition of LLXfer_File class for a single xfer_file. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,13 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLXFER_FILE_H #define LL_LLXFER_FILE_H -#include - #include "llxfer.h" #include "lldir.h" diff --git a/linden/indra/llmessage/llxfer_mem.cpp b/linden/indra/llmessage/llxfer_mem.cpp index 223ce08..4c3b1bb 100644 --- a/linden/indra/llmessage/llxfer_mem.cpp +++ b/linden/indra/llmessage/llxfer_mem.cpp @@ -2,6 +2,8 @@ * @file llxfer_mem.cpp * @brief implementation of LLXfer_Mem class for a single xfer * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llxfer_mem.h b/linden/indra/llmessage/llxfer_mem.h index 8523c7d..858b8d1 100644 --- a/linden/indra/llmessage/llxfer_mem.h +++ b/linden/indra/llmessage/llxfer_mem.h @@ -2,6 +2,8 @@ * @file llxfer_mem.h * @brief definition of LLXfer_Mem class for a single xfer * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,13 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLXFER_MEM_H #define LL_LLXFER_MEM_H -#include - #include "message.h" #include "lltimer.h" #include "llxfer.h" diff --git a/linden/indra/llmessage/llxfer_vfile.cpp b/linden/indra/llmessage/llxfer_vfile.cpp index 54b9683..b870e53 100644 --- a/linden/indra/llmessage/llxfer_vfile.cpp +++ b/linden/indra/llmessage/llxfer_vfile.cpp @@ -2,6 +2,8 @@ * @file llxfer_vfile.cpp * @brief implementation of LLXfer_VFile class for a single xfer (vfile). * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llxfer_vfile.h b/linden/indra/llmessage/llxfer_vfile.h index 1362749..5d57b08 100644 --- a/linden/indra/llmessage/llxfer_vfile.h +++ b/linden/indra/llmessage/llxfer_vfile.h @@ -2,6 +2,8 @@ * @file llxfer_vfile.h * @brief definition of LLXfer_VFile class for a single xfer_vfile. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,13 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLXFER_VFILE_H #define LL_LLXFER_VFILE_H -#include - #include "llxfer.h" #include "llassetstorage.h" diff --git a/linden/indra/llmessage/llxfermanager.cpp b/linden/indra/llmessage/llxfermanager.cpp index b9a2c3e..c4dd340 100644 --- a/linden/indra/llmessage/llxfermanager.cpp +++ b/linden/indra/llmessage/llxfermanager.cpp @@ -2,6 +2,8 @@ * @file llxfermanager.cpp * @brief implementation of LLXferManager class for a collection of xfers * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llxfermanager.h b/linden/indra/llmessage/llxfermanager.h index 62969d9..5d213bb 100644 --- a/linden/indra/llmessage/llxfermanager.h +++ b/linden/indra/llmessage/llxfermanager.h @@ -3,6 +3,8 @@ * @brief definition of LLXferManager class for a keeping track of * multiple xfers * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLXFERMANAGER_H diff --git a/linden/indra/llmessage/llxorcipher.cpp b/linden/indra/llmessage/llxorcipher.cpp index 042fbd4..c659d3f 100644 --- a/linden/indra/llmessage/llxorcipher.cpp +++ b/linden/indra/llmessage/llxorcipher.cpp @@ -2,6 +2,8 @@ * @file llxorcipher.cpp * @brief Implementation of LLXORCipher * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/llxorcipher.h b/linden/indra/llmessage/llxorcipher.h index 16579a6..4c7a846 100644 --- a/linden/indra/llmessage/llxorcipher.h +++ b/linden/indra/llmessage/llxorcipher.h @@ -1,6 +1,8 @@ /** * @file llxorcipher.h * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLXORCIPHER_H diff --git a/linden/indra/llmessage/machine.h b/linden/indra/llmessage/machine.h index b28e621..b210250 100644 --- a/linden/indra/llmessage/machine.h +++ b/linden/indra/llmessage/machine.h @@ -2,6 +2,8 @@ * @file machine.h * @brief LLMachine class header file * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_MACHINE_H diff --git a/linden/indra/llmessage/mean_collision_data.h b/linden/indra/llmessage/mean_collision_data.h index a319640..1643c30 100644 --- a/linden/indra/llmessage/mean_collision_data.h +++ b/linden/indra/llmessage/mean_collision_data.h @@ -3,6 +3,8 @@ * @brief data type to log interactions between stuff and agents that * might be community standards violations * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,13 +27,14 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_MEAN_COLLISIONS_DATA_H #define LL_MEAN_COLLISIONS_DATA_H -#include #include "lldbstrings.h" +#include "lluuid.h" const F32 MEAN_COLLISION_TIMEOUT = 5.f; const S32 MAX_MEAN_COLLISIONS = 5; diff --git a/linden/indra/llmessage/message.cpp b/linden/indra/llmessage/message.cpp index 70b8166..e2cd19b 100644 --- a/linden/indra/llmessage/message.cpp +++ b/linden/indra/llmessage/message.cpp @@ -2,6 +2,8 @@ * @file message.cpp * @brief LLMessageSystem class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -38,10 +41,6 @@ #include #include #endif -#include -#include -#include -#include #include #include #include @@ -375,8 +374,8 @@ void LLMessageSystem::loadTemplateFile(const char* filename) return; } - LLString template_body; - if(!LLString::read(template_body, filename)) + std::string template_body; + if(!_read_file_into_string(template_body, filename)) { llwarns << "Failed to open template: " << filename << llendl; mbError = TRUE; @@ -1155,9 +1154,11 @@ LLHTTPClient::ResponderPtr LLMessageSystem::createResponder(const std::string& n } else { - llwarns << "LLMessageSystem::sendMessage: Sending unreliable " - << mMessageBuilder->getMessageName() << " message via HTTP" - << llendl; + // These messages aren't really unreliable, they just weren't + // explicitly sent as reliable, so they don't have a callback +// llwarns << "LLMessageSystem::sendMessage: Sending unreliable " +// << mMessageBuilder->getMessageName() << " message via HTTP" +// << llendl; return new LLFnPtrResponder(NULL, NULL, mMessageBuilder->getMessageName()); } @@ -2403,8 +2404,8 @@ void dump_prehash_files() " * @file message_prehash.h\n" " * @brief header file of externs of prehashed variables plus defines.\n" " *\n" - " * Copyright (c) 2003-$CurrentYear$, Linden Research, Inc.\n" - " * $License$\n" + " * $LicenseInfo:firstyear=2003&license=viewergpl$" + " * $/LicenseInfo$" " */\n\n" "#ifndef LL_MESSAGE_PREHASH_H\n#define LL_MESSAGE_PREHASH_H\n\n"); fprintf( @@ -2435,8 +2436,8 @@ void dump_prehash_files() " * @file message_prehash.cpp\n" " * @brief file of prehashed variables\n" " *\n" - " * Copyright (c) 2003-$CurrentYear$, Linden Research, Inc.\n" - " * $License$\n" + " * $LicenseInfo:firstyear=2003&license=viewergpl$" + " * $/LicenseInfo$" " */\n\n" "/**\n" " * Generated from message template version number %.3f\n" diff --git a/linden/indra/llmessage/message.h b/linden/indra/llmessage/message.h index d18bd09..4454b40 100644 --- a/linden/indra/llmessage/message.h +++ b/linden/indra/llmessage/message.h @@ -2,6 +2,8 @@ * @file message.h * @brief LLMessageSystem class header file * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,14 +26,13 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_MESSAGE_H #define LL_MESSAGE_H #include -#include -#include #include #if LL_LINUX diff --git a/linden/indra/llmessage/message_prehash.cpp b/linden/indra/llmessage/message_prehash.cpp index ce532e1..0185c0f 100644 --- a/linden/indra/llmessage/message_prehash.cpp +++ b/linden/indra/llmessage/message_prehash.cpp @@ -2,6 +2,8 @@ * @file message_prehash.cpp * @brief file of prehashed variables * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /** diff --git a/linden/indra/llmessage/message_prehash.h b/linden/indra/llmessage/message_prehash.h index 672cd14..2cea924 100644 --- a/linden/indra/llmessage/message_prehash.h +++ b/linden/indra/llmessage/message_prehash.h @@ -2,6 +2,8 @@ * @file message_prehash.h * @brief header file of externs of prehashed variables plus defines. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_MESSAGE_PREHASH_H diff --git a/linden/indra/llmessage/message_string_table.cpp b/linden/indra/llmessage/message_string_table.cpp index 2ae269b..bc44239 100644 --- a/linden/indra/llmessage/message_string_table.cpp +++ b/linden/indra/llmessage/message_string_table.cpp @@ -2,6 +2,8 @@ * @file message_string_table.cpp * @brief static string table for message template * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/net.cpp b/linden/indra/llmessage/net.cpp index 92efd15..50b3414 100644 --- a/linden/indra/llmessage/net.cpp +++ b/linden/indra/llmessage/net.cpp @@ -2,6 +2,8 @@ * @file net.cpp * @brief Cross-platform routines for sending and receiving packets. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -32,7 +35,6 @@ // system library includes #include -#include #if LL_WINDOWS #define WIN32_LEAN_AND_MEAN diff --git a/linden/indra/llmessage/net.h b/linden/indra/llmessage/net.h index cfc1f88..b6fa48d 100644 --- a/linden/indra/llmessage/net.h +++ b/linden/indra/llmessage/net.h @@ -2,6 +2,8 @@ * @file net.h * @brief Cross platform UDP network code. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_NET_H diff --git a/linden/indra/llmessage/network.cpp b/linden/indra/llmessage/network.cpp index 03aad63..ab3df02 100644 --- a/linden/indra/llmessage/network.cpp +++ b/linden/indra/llmessage/network.cpp @@ -2,6 +2,8 @@ * @file network.cpp * @brief Legacy file * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,5 +26,6 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ diff --git a/linden/indra/llmessage/network.h b/linden/indra/llmessage/network.h index 6c6577b..8a1111d 100644 --- a/linden/indra/llmessage/network.h +++ b/linden/indra/llmessage/network.h @@ -2,6 +2,8 @@ * @file network.h * @brief Legacy file. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,5 +26,6 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ diff --git a/linden/indra/llmessage/partsyspacket.cpp b/linden/indra/llmessage/partsyspacket.cpp index 4750faa..d27c069 100644 --- a/linden/indra/llmessage/partsyspacket.cpp +++ b/linden/indra/llmessage/partsyspacket.cpp @@ -3,6 +3,8 @@ * @brief Object for packing particle system initialization parameters * before sending them over the network. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/partsyspacket.h b/linden/indra/llmessage/partsyspacket.h index 5dbc41c..c7d001c 100644 --- a/linden/indra/llmessage/partsyspacket.h +++ b/linden/indra/llmessage/partsyspacket.h @@ -3,6 +3,8 @@ * @brief Object for packing particle system initialization parameters * before sending them over the network * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_PARTSYSPACKET_H diff --git a/linden/indra/llmessage/patch_code.cpp b/linden/indra/llmessage/patch_code.cpp index c996899..cea8635 100644 --- a/linden/indra/llmessage/patch_code.cpp +++ b/linden/indra/llmessage/patch_code.cpp @@ -2,6 +2,8 @@ * @file patch_code.cpp * @brief Encode patch DCT data into bitcode. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/patch_code.h b/linden/indra/llmessage/patch_code.h index ba3dea4..f8ee39c 100644 --- a/linden/indra/llmessage/patch_code.h +++ b/linden/indra/llmessage/patch_code.h @@ -2,6 +2,8 @@ * @file patch_code.h * @brief Function declarations for encoding and decoding patches. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_PATCH_CODE_H diff --git a/linden/indra/llmessage/patch_dct.cpp b/linden/indra/llmessage/patch_dct.cpp index 0e8aa25..69f6a2d 100644 --- a/linden/indra/llmessage/patch_dct.cpp +++ b/linden/indra/llmessage/patch_dct.cpp @@ -2,6 +2,8 @@ * @file patch_dct.cpp * @brief DCT patch. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/patch_dct.h b/linden/indra/llmessage/patch_dct.h index b69249e..b6e7ba4 100644 --- a/linden/indra/llmessage/patch_dct.h +++ b/linden/indra/llmessage/patch_dct.h @@ -2,6 +2,8 @@ * @file patch_dct.h * @brief Function declarations for DCT and IDCT routines * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_PATCH_DCT_H diff --git a/linden/indra/llmessage/patch_idct.cpp b/linden/indra/llmessage/patch_idct.cpp index 680003a..61c10bd 100644 --- a/linden/indra/llmessage/patch_idct.cpp +++ b/linden/indra/llmessage/patch_idct.cpp @@ -2,6 +2,8 @@ * @file patch_idct.cpp * @brief IDCT patch. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llmessage/sound_ids.h b/linden/indra/llmessage/sound_ids.h index 2652778..a8efdae 100644 --- a/linden/indra/llmessage/sound_ids.h +++ b/linden/indra/llmessage/sound_ids.h @@ -2,6 +2,8 @@ * @file sound_ids.h * @brief Temporary holder for sound IDs. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_SOUND_IDS_H diff --git a/linden/indra/llprimitive/legacy_object_types.h b/linden/indra/llprimitive/legacy_object_types.h index 9cdc632..09fd72a 100644 --- a/linden/indra/llprimitive/legacy_object_types.h +++ b/linden/indra/llprimitive/legacy_object_types.h @@ -2,6 +2,8 @@ * @file legacy_object_types.h * @brief Byte codes for basic object and primitive types * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LEGACY_OBJECT_TYPES_H diff --git a/linden/indra/llprimitive/llmaterialtable.cpp b/linden/indra/llprimitive/llmaterialtable.cpp index d7ac57a..9970a03 100644 --- a/linden/indra/llprimitive/llmaterialtable.cpp +++ b/linden/indra/llprimitive/llmaterialtable.cpp @@ -2,6 +2,8 @@ * @file llmaterialtable.cpp * @brief Table of material names and IDs for viewer * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llprimitive/llmaterialtable.h b/linden/indra/llprimitive/llmaterialtable.h index d9596e1..e786a86 100644 --- a/linden/indra/llprimitive/llmaterialtable.h +++ b/linden/indra/llprimitive/llmaterialtable.h @@ -2,6 +2,8 @@ * @file llmaterialtable.h * @brief Table of material information for the viewer UI * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMATERIALTABLE_H diff --git a/linden/indra/llprimitive/llprimitive.cpp b/linden/indra/llprimitive/llprimitive.cpp index 1dfc570..b418793 100644 --- a/linden/indra/llprimitive/llprimitive.cpp +++ b/linden/indra/llprimitive/llprimitive.cpp @@ -2,6 +2,8 @@ * @file llprimitive.cpp * @brief LLPrimitive base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -860,6 +863,7 @@ void LLPrimitive::copyTEs(const LLPrimitive *primitivep) setTERotation(i, tep->getRotation()); setTEBumpShinyFullbright(i, tep->getBumpShinyFullbright()); setTEMediaTexGen(i, tep->getMediaTexGen()); + setTEGlow(i, tep->getGlow()); } } @@ -1657,6 +1661,52 @@ void LLPrimitive::setTextureList(LLTextureEntry *listp) //============================================================================ +// Moved from llselectmgr.cpp +// BUG: Only works for boxes. +// Face numbering for flex boxes as of 1.14.2 + +// static +bool LLPrimitive::getTESTAxes(const U8 face, U32* s_axis, U32* t_axis) +{ + if (face == 0) + { + *s_axis = VX; *t_axis = VY; + return true; + } + else if (face == 1) + { + *s_axis = VX; *t_axis = VZ; + return true; + } + else if (face == 2) + { + *s_axis = VY; *t_axis = VZ; + return true; + } + else if (face == 3) + { + *s_axis = VX; *t_axis = VZ; + return true; + } + else if (face == 4) + { + *s_axis = VY; *t_axis = VZ; + return true; + } + else if (face == 5) + { + *s_axis = VX; *t_axis = VY; + return true; + } + else + { + // unknown face + return false; + } +} + +//============================================================================ + //static BOOL LLNetworkData::isValid(U16 param_type, U32 size) { diff --git a/linden/indra/llprimitive/llprimitive.h b/linden/indra/llprimitive/llprimitive.h index 1a568d1..53b17bc 100644 --- a/linden/indra/llprimitive/llprimitive.h +++ b/linden/indra/llprimitive/llprimitive.h @@ -2,6 +2,8 @@ * @file llprimitive.h * @brief LLPrimitive base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPRIMITIVE_H @@ -359,7 +362,8 @@ public: static const char *pCodeToString(const LLPCode pcode); static LLPCode legacyToPCode(const U8 legacy); static U8 pCodeToLegacy(const LLPCode pcode); - + static bool getTESTAxes(const U8 face, U32* s_axis, U32* t_axis); + inline static BOOL isPrimitive(const LLPCode pcode); inline static BOOL isApp(const LLPCode pcode); diff --git a/linden/indra/llprimitive/lltextureanim.cpp b/linden/indra/llprimitive/lltextureanim.cpp index e373a29..b15e5a8 100644 --- a/linden/indra/llprimitive/lltextureanim.cpp +++ b/linden/indra/llprimitive/lltextureanim.cpp @@ -2,6 +2,8 @@ * @file lltextureanim.cpp * @brief LLTextureAnim base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llprimitive/lltextureanim.h b/linden/indra/llprimitive/lltextureanim.h index 502cf54..32e66da 100644 --- a/linden/indra/llprimitive/lltextureanim.h +++ b/linden/indra/llprimitive/lltextureanim.h @@ -2,6 +2,8 @@ * @file lltextureanim.h * @brief LLTextureAnim base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTEXTUREANIM_H diff --git a/linden/indra/llprimitive/lltextureentry.cpp b/linden/indra/llprimitive/lltextureentry.cpp index 73ecd96..e6eee9b 100644 --- a/linden/indra/llprimitive/lltextureentry.cpp +++ b/linden/indra/llprimitive/lltextureentry.cpp @@ -2,6 +2,8 @@ * @file lltextureentry.cpp * @brief LLTextureEntry base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llprimitive/lltextureentry.h b/linden/indra/llprimitive/lltextureentry.h index c1f355b..960d97b 100644 --- a/linden/indra/llprimitive/lltextureentry.h +++ b/linden/indra/llprimitive/lltextureentry.h @@ -2,6 +2,8 @@ * @file lltextureentry.h * @brief LLTextureEntry base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTEXTUREENTRY_H @@ -144,6 +147,10 @@ protected: U8 mBump; // Bump map, shiny, and fullbright U8 mMediaFlags; // replace with web page, movie, etc. F32 mGlow; + + // NOTE: when adding new data to this class, in addition to adding it to the serializers asLLSD/fromLLSD and the + // message packers (e.g. LLPrimitive::packTEMessage) you must also implement its copy in LLPrimitive::copyTEs() + }; diff --git a/linden/indra/llprimitive/lltree_common.h b/linden/indra/llprimitive/lltree_common.h index f9594e2..302e938 100644 --- a/linden/indra/llprimitive/lltree_common.h +++ b/linden/indra/llprimitive/lltree_common.h @@ -2,6 +2,8 @@ * @file lltree_common.h * @brief LLTree_gene_0 base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Common data for trees shared between simulator and viewer diff --git a/linden/indra/llprimitive/lltreeparams.cpp b/linden/indra/llprimitive/lltreeparams.cpp index fde21f0..ba038ff 100644 --- a/linden/indra/llprimitive/lltreeparams.cpp +++ b/linden/indra/llprimitive/lltreeparams.cpp @@ -2,6 +2,8 @@ * @file lltreeparams.cpp * @brief implementation of the LLTreeParams class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ ////////////////////////////////////////////////////////////////////// diff --git a/linden/indra/llprimitive/lltreeparams.h b/linden/indra/llprimitive/lltreeparams.h index 2754eb4..c4bb1ea 100644 --- a/linden/indra/llprimitive/lltreeparams.h +++ b/linden/indra/llprimitive/lltreeparams.h @@ -2,6 +2,8 @@ * @file lltreeparams.h * @brief Implementation of the LLTreeParams class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTREEPARAMS_H diff --git a/linden/indra/llprimitive/llvolumemessage.cpp b/linden/indra/llprimitive/llvolumemessage.cpp index 650e0cd..c7efc86 100644 --- a/linden/indra/llprimitive/llvolumemessage.cpp +++ b/linden/indra/llprimitive/llvolumemessage.cpp @@ -2,6 +2,8 @@ * @file llvolumemessage.cpp * @brief LLVolumeMessage base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llprimitive/llvolumemessage.h b/linden/indra/llprimitive/llvolumemessage.h index e626a04..7e7da3d 100644 --- a/linden/indra/llprimitive/llvolumemessage.h +++ b/linden/indra/llprimitive/llvolumemessage.h @@ -2,6 +2,8 @@ * @file llvolumemessage.h * @brief LLVolumeMessage base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVOLUMEMESSAGE_H diff --git a/linden/indra/llprimitive/llvolumexml.cpp b/linden/indra/llprimitive/llvolumexml.cpp index 370f152..c9af11c 100644 --- a/linden/indra/llprimitive/llvolumexml.cpp +++ b/linden/indra/llprimitive/llvolumexml.cpp @@ -2,6 +2,8 @@ * @file llvolumexml.cpp * @brief LLVolumeXml base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llprimitive/llvolumexml.h b/linden/indra/llprimitive/llvolumexml.h index 0a3d1c5..8bec5f7 100644 --- a/linden/indra/llprimitive/llvolumexml.h +++ b/linden/indra/llprimitive/llvolumexml.h @@ -2,6 +2,8 @@ * @file llvolumexml.h * @brief LLVolumeXml base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVOLUMEXML_H diff --git a/linden/indra/llprimitive/material_codes.h b/linden/indra/llprimitive/material_codes.h index 01a5573..8e77a43 100644 --- a/linden/indra/llprimitive/material_codes.h +++ b/linden/indra/llprimitive/material_codes.h @@ -2,6 +2,8 @@ * @file material_codes.h * @brief Material_codes definitions * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_MATERIAL_CODES_H diff --git a/linden/indra/llprimitive/object_flags.h b/linden/indra/llprimitive/object_flags.h index e7bf023..cc37d06 100644 --- a/linden/indra/llprimitive/object_flags.h +++ b/linden/indra/llprimitive/object_flags.h @@ -2,6 +2,8 @@ * @file object_flags.h * @brief Flags for object creation and transmission * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_OBJECT_FLAGS_H @@ -46,7 +49,8 @@ const U32 FLAGS_INVENTORY_EMPTY = 0x00000800; const U32 FLAGS_JOINT_HINGE = 0x00001000; const U32 FLAGS_JOINT_P2P = 0x00002000; const U32 FLAGS_JOINT_LP2P = 0x00004000; -//const U32 FLAGS_JOINT_WHEEL = 0x00008000; +// const U32 FLAGS_JOINT_WHEEL = 0x00008000; +const U32 FLAGS_INCLUDE_IN_SEARCH = 0x00008000; const U32 FLAGS_ALLOW_INVENTORY_DROP = 0x00010000; const U32 FLAGS_OBJECT_TRANSFER = 0x00020000; diff --git a/linden/indra/llrender/llfont.cpp b/linden/indra/llrender/llfont.cpp index b07d0d6..c638a35 100644 --- a/linden/indra/llrender/llfont.cpp +++ b/linden/indra/llrender/llfont.cpp @@ -2,6 +2,8 @@ * @file llfont.cpp * @brief Font library wrapper * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llrender/llfont.h b/linden/indra/llrender/llfont.h index f10f7bb..88c2a7d 100644 --- a/linden/indra/llrender/llfont.h +++ b/linden/indra/llrender/llfont.h @@ -2,6 +2,8 @@ * @file llfont.h * @brief Font library wrapper * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFONT_H diff --git a/linden/indra/llrender/llfontgl.cpp b/linden/indra/llrender/llfontgl.cpp index 23f02c2..dd67dbc 100644 --- a/linden/indra/llrender/llfontgl.cpp +++ b/linden/indra/llrender/llfontgl.cpp @@ -2,6 +2,8 @@ * @file llfontgl.cpp * @brief Wrapper around FreeType * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llrender/llfontgl.h b/linden/indra/llrender/llfontgl.h index 2cd62c6..393d26c 100644 --- a/linden/indra/llrender/llfontgl.h +++ b/linden/indra/llrender/llfontgl.h @@ -3,6 +3,8 @@ * @author Doug Soo * @brief Wrapper around FreeType * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFONTGL_H diff --git a/linden/indra/llrender/llgldbg.cpp b/linden/indra/llrender/llgldbg.cpp index 84f0082..59a818d 100644 --- a/linden/indra/llrender/llgldbg.cpp +++ b/linden/indra/llrender/llgldbg.cpp @@ -2,6 +2,8 @@ * @file llgldbg.cpp * @brief Definitions for OpenGL debugging support * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // This file sets some global GL parameters, and implements some diff --git a/linden/indra/llrender/llgldbg.h b/linden/indra/llrender/llgldbg.h index 4483fb9..8f39005 100644 --- a/linden/indra/llrender/llgldbg.h +++ b/linden/indra/llrender/llgldbg.h @@ -2,6 +2,8 @@ * @file llgldbg.h * @brief Definitions for OpenGL debugging support * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLGLDBG_H diff --git a/linden/indra/llrender/llimagegl.cpp b/linden/indra/llrender/llimagegl.cpp index a2e5abc..00f167c 100644 --- a/linden/indra/llrender/llimagegl.cpp +++ b/linden/indra/llrender/llimagegl.cpp @@ -2,6 +2,8 @@ * @file llimagegl.cpp * @brief Generic GL image handler * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ diff --git a/linden/indra/llrender/llimagegl.h b/linden/indra/llrender/llimagegl.h index 3bdd1c9..491fbb5 100644 --- a/linden/indra/llrender/llimagegl.h +++ b/linden/indra/llrender/llimagegl.h @@ -2,6 +2,8 @@ * @file llimagegl.h * @brief Object for managing images and their textures * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ diff --git a/linden/indra/llrender/llvertexbuffer.cpp b/linden/indra/llrender/llvertexbuffer.cpp index 7f24313..2a54fca 100644 --- a/linden/indra/llrender/llvertexbuffer.cpp +++ b/linden/indra/llrender/llvertexbuffer.cpp @@ -2,6 +2,8 @@ * @file llvertexbuffer.cpp * @brief LLVertexBuffer implementation * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llrender/llvertexbuffer.h b/linden/indra/llrender/llvertexbuffer.h index 62c6124..cf36eb6 100644 --- a/linden/indra/llrender/llvertexbuffer.h +++ b/linden/indra/llrender/llvertexbuffer.h @@ -2,6 +2,8 @@ * @file llvertexbuffer.h * @brief LLVertexBuffer wrapper for OpengGL vertex buffer objects * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVERTEXBUFFER_H diff --git a/linden/indra/llrender/llvertexprogramgl.cpp b/linden/indra/llrender/llvertexprogramgl.cpp index 5a65a5f..43f6424 100644 --- a/linden/indra/llrender/llvertexprogramgl.cpp +++ b/linden/indra/llrender/llvertexprogramgl.cpp @@ -2,6 +2,8 @@ * @file llvertexprogramgl.cpp * @brief LLVertexProgramGL base class * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // This file contains the definition of LLVertexProgramGL, diff --git a/linden/indra/llrender/llvertexprogramgl.h b/linden/indra/llrender/llvertexprogramgl.h index cf6ac37..00aa05c 100644 --- a/linden/indra/llrender/llvertexprogramgl.h +++ b/linden/indra/llrender/llvertexprogramgl.h @@ -2,6 +2,8 @@ * @file llvertexprogramgl.h * @brief LLVertexProgramGL base class * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVERTEXPROGRAMGL_H diff --git a/linden/indra/llui/llalertdialog.cpp b/linden/indra/llui/llalertdialog.cpp index 8950fcd..0fa3585 100644 --- a/linden/indra/llui/llalertdialog.cpp +++ b/linden/indra/llui/llalertdialog.cpp @@ -2,6 +2,8 @@ * @file llalertdialog.cpp * @brief LLAlertDialog base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -255,11 +258,9 @@ void LLAlertDialog::createDialog(const std::vector* optionsp, S32 defa const S32 LINE_HEIGHT = llfloor(font->getLineHeight() + 0.99f); const S32 EDITOR_HEIGHT = 20; - // buttons + // Buttons std::vector default_option_list; - mNumOptions = optionsp->size(); - if( 0 == mNumOptions ) { default_option_list.push_back("Close"); @@ -269,7 +270,6 @@ void LLAlertDialog::createDialog(const std::vector* optionsp, S32 defa } const std::vector& options = *optionsp; - mButtonData = new ButtonData[mNumOptions]; // Calc total width of buttons @@ -286,55 +286,16 @@ void LLAlertDialog::createDialog(const std::vector* optionsp, S32 defa btn_total_width = (mNumOptions * button_width) + ((mNumOptions - 1) * BTN_HPAD); } - // Split message into lines, separated by '\n' + // Message: create text box using raw string, as text has been structure deliberately + // Use size of created text box to generate dialog box size LLString msg = msg_in; - LLAlertDialog::format(msg, args); - + LLAlertDialog::format( msg, args ); llwarns << "Alert: " << msg << llendl; + LLTextBox* msg_box = new LLTextBox( "Alert message", msg, (F32)MAX_ALLOWED_MSG_WIDTH, font ); - S32 max_msg_width = 0; - std::vector msg_lines; - - boost_tokenizer tokens(msg, boost::char_separator("\n")); - for (boost_tokenizer::iterator token_iter = tokens.begin(); token_iter != tokens.end(); ++token_iter) - { - LLString line(*token_iter); - boost_tokenizer line_toks(line, boost::char_separator(" \t")); - LLString cur_line; - S32 cur_line_width = 0; - for (boost_tokenizer::iterator token_iter2 = line_toks.begin(); token_iter2 != line_toks.end(); ++token_iter2) - { - LLString tok(*token_iter2); - LLString word; - if (cur_line_width > 0) - { - word = " "; - } - word += tok; - S32 word_width = S32(font->getWidth( word ) + 0.99f); - if (cur_line_width > 0 && cur_line_width + word_width > MAX_ALLOWED_MSG_WIDTH) - { - max_msg_width = llmax( max_msg_width, cur_line_width + MSG_PAD); - msg_lines.push_back( cur_line ); - cur_line.clear(); - cur_line_width = 0; - word = tok; // no ' ' - } - cur_line += word; - cur_line_width += word_width; - } - if (cur_line_width > 0) - { - max_msg_width = llmax( max_msg_width, cur_line_width ); - msg_lines.push_back( cur_line ); - } - } - - // pad message box so we don't clip last character - max_msg_width += 2; - - S32 dialog_width = llmax( btn_total_width, max_msg_width ) + 2 * HPAD; - S32 dialog_height = LINE_HEIGHT * msg_lines.size() + 3 * VPAD + BTN_HEIGHT; + const LLRect& text_rect = msg_box->getRect(); + S32 dialog_width = llmax( btn_total_width, text_rect.getWidth() ) + 2 * HPAD; + S32 dialog_height = text_rect.getHeight() + 3 * VPAD + BTN_HEIGHT; if (hasTitleBar()) { @@ -346,26 +307,20 @@ void LLAlertDialog::createDialog(const std::vector* optionsp, S32 defa dialog_width = llmax(dialog_width, S32(font->getWidth( edit_text ) + 0.99f)); dialog_height += EDITOR_HEIGHT; } - + reshape( dialog_width, dialog_height, FALSE ); - // Message - S32 msg_x = (mRect.getWidth() - max_msg_width) / 2; - S32 msg_y = mRect.getHeight() - VPAD - LINE_HEIGHT; + S32 msg_y = mRect.getHeight() - VPAD; if (hasTitleBar()) { msg_y -= LINE_HEIGHT; // room for title } - - for( std::vector::iterator iter = msg_lines.begin(); iter != msg_lines.end(); ++iter ) - { - LLRect msg_rect; - msg_rect.setOriginAndSize( msg_x, msg_y, max_msg_width, LINE_HEIGHT ); - LLTextBox* label_box = new LLTextBox( "Alert message", msg_rect, iter->c_str(), font ); - label_box->setColor( LLUI::sColorsGroup->getColor( "LabelTextColor" ) ); - addChild(label_box); - msg_y -= LINE_HEIGHT; - } + + LLRect rect; + rect.setLeftTopAndSize( HPAD, msg_y, text_rect.getWidth(), text_rect.getHeight() ); + msg_box->setRect( rect ); + msg_box->setColor( LLUI::sColorsGroup->getColor( "LabelTextColor" ) ); + addChild(msg_box); // Buttons S32 button_left = (mRect.getWidth() - btn_total_width) / 2; @@ -386,7 +341,7 @@ void LLAlertDialog::createDialog(const std::vector* optionsp, S32 defa mButtonData[i].mSelf = this; mButtonData[i].mButton = btn; mButtonData[i].mOption = i; - + addChild(btn); if( i == default_option ) @@ -402,13 +357,12 @@ void LLAlertDialog::createDialog(const std::vector* optionsp, S32 defa { S32 y = VPAD + BTN_HEIGHT + VPAD/2; mLineEditor = new LLLineEditor("lineeditor", - LLRect( HPAD, y+EDITOR_HEIGHT, dialog_width-HPAD, y), - edit_text, - LLFontGL::sSansSerif, - STD_STRING_STR_LEN); + LLRect( HPAD, y+EDITOR_HEIGHT, dialog_width-HPAD, y), + edit_text, + LLFontGL::sSansSerif, + STD_STRING_STR_LEN); addChild(mLineEditor); } - } bool LLAlertDialog::setCheckBox( const LLString& check_title, const LLString& check_control ) diff --git a/linden/indra/llui/llalertdialog.h b/linden/indra/llui/llalertdialog.h index 1add4a4..acd0b7f 100644 --- a/linden/indra/llui/llalertdialog.h +++ b/linden/indra/llui/llalertdialog.h @@ -2,6 +2,8 @@ * @file llalertdialog.h * @brief LLAlertDialog base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_ALERTDIALOG_H @@ -139,7 +142,7 @@ public: class LLAlertDialogTemplate : public LLRefCount { public: - LLAlertDialogTemplate() : mTitle(""), mModal(FALSE), mUnique(FALSE), mIgnorable(0), mDefaultOption(0) {} + LLAlertDialogTemplate() : mTitle(), mModal(FALSE), mUnique(FALSE), mIgnorable(0), mDefaultOption(0) {} void addOption(const LLString& label, const LLString& ignore_text, BOOL is_default = FALSE) { diff --git a/linden/indra/llui/llbutton.cpp b/linden/indra/llui/llbutton.cpp index 6ed6885..65cbcf3 100644 --- a/linden/indra/llui/llbutton.cpp +++ b/linden/indra/llui/llbutton.cpp @@ -2,6 +2,8 @@ * @file llbutton.cpp * @brief LLButton base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -773,36 +776,36 @@ LLSD LLButton::getValue() const return mToggleState; } -void LLButton::setLabel( const LLString& label ) +void LLButton::setLabel( const LLStringExplicit& label ) { setLabelUnselected(label); setLabelSelected(label); } //virtual -BOOL LLButton::setLabelArg( const LLString& key, const LLString& text ) +BOOL LLButton::setLabelArg( const LLString& key, const LLStringExplicit& text ) { mUnselectedLabel.setArg(key, text); mSelectedLabel.setArg(key, text); return TRUE; } -void LLButton::setLabelUnselected( const LLString& label ) +void LLButton::setLabelUnselected( const LLStringExplicit& label ) { mUnselectedLabel = label; } -void LLButton::setLabelSelected( const LLString& label ) +void LLButton::setLabelSelected( const LLStringExplicit& label ) { mSelectedLabel = label; } -void LLButton::setDisabledLabel( const LLString& label ) +void LLButton::setDisabledLabel( const LLStringExplicit& label ) { mDisabledLabel = label; } -void LLButton::setDisabledSelectedLabel( const LLString& label ) +void LLButton::setDisabledSelectedLabel( const LLStringExplicit& label ) { mDisabledSelectedLabel = label; } diff --git a/linden/indra/llui/llbutton.h b/linden/indra/llui/llbutton.h index d26011b..5f7d917 100644 --- a/linden/indra/llui/llbutton.h +++ b/linden/indra/llui/llbutton.h @@ -2,6 +2,8 @@ * @file llbutton.h * @brief Header for buttons * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLBUTTON_H @@ -65,7 +68,7 @@ class LLButton { public: // simple button with text label - LLButton(const LLString& name, const LLRect &rect, const LLString& control_name = "", + LLButton(const LLString& name, const LLRect &rect, const LLString& control_name = LLString(), void (*on_click)(void*) = NULL, void *data = NULL); LLButton(const LLString& name, const LLRect& rect, @@ -149,12 +152,12 @@ public: virtual void setValue(const LLSD& value ); virtual LLSD getValue() const; - void setLabel( const LLString& label); - virtual BOOL setLabelArg( const LLString& key, const LLString& text ); - void setLabelUnselected(const LLString& label); - void setLabelSelected(const LLString& label); - void setDisabledLabel(const LLString& disabled_label); - void setDisabledSelectedLabel(const LLString& disabled_label); + void setLabel( const LLStringExplicit& label); + virtual BOOL setLabelArg( const LLString& key, const LLStringExplicit& text ); + void setLabelUnselected(const LLStringExplicit& label); + void setLabelSelected(const LLStringExplicit& label); + void setDisabledLabel(const LLStringExplicit& disabled_label); + void setDisabledSelectedLabel(const LLStringExplicit& disabled_label); void setDisabledLabelColor( const LLColor4& c ) { mDisabledLabelColor = c; } void setFont(const LLFontGL *font) @@ -285,12 +288,12 @@ class LLSquareButton { public: LLSquareButton(const LLString& name, const LLRect& rect, - const LLString& label, - const LLFontGL *font = NULL, - const LLString& control_name = "", - void (*click_callback)(void*) = NULL, - void *callback_data = NULL, - const LLString& selected_label = LLString::null ); + const LLString& label, + const LLFontGL *font = NULL, + const LLString& control_name = LLString(), + void (*click_callback)(void*) = NULL, + void *callback_data = NULL, + const LLString& selected_label = LLString::null ); }; // Helpful functions diff --git a/linden/indra/llui/llcallbackmap.h b/linden/indra/llui/llcallbackmap.h index 4a47f60..0efda5d 100644 --- a/linden/indra/llui/llcallbackmap.h +++ b/linden/indra/llui/llcallbackmap.h @@ -2,6 +2,8 @@ * @file llcallbackmap.h * @brief LLCallbackMap base class * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // llcallbackmap.h diff --git a/linden/indra/llui/llcheckboxctrl.cpp b/linden/indra/llui/llcheckboxctrl.cpp index f49e220..504b342 100644 --- a/linden/indra/llui/llcheckboxctrl.cpp +++ b/linden/indra/llui/llcheckboxctrl.cpp @@ -2,6 +2,8 @@ * @file llcheckboxctrl.cpp * @brief LLCheckBoxCtrl base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // The mutants are coming! @@ -239,7 +242,7 @@ LLSD LLCheckBoxCtrl::getValue() const return mButton->getToggleState(); } -void LLCheckBoxCtrl::setLabel( const LLString& label ) +void LLCheckBoxCtrl::setLabel( const LLStringExplicit& label ) { mLabel->setText( label ); reshape(getRect().getWidth(), getRect().getHeight(), FALSE); @@ -250,7 +253,7 @@ LLString LLCheckBoxCtrl::getLabel() const return mLabel->getText(); } -BOOL LLCheckBoxCtrl::setLabelArg( const LLString& key, const LLString& text ) +BOOL LLCheckBoxCtrl::setLabelArg( const LLString& key, const LLStringExplicit& text ) { BOOL res = mLabel->setTextArg(key, text); reshape(getRect().getWidth(), getRect().getHeight(), FALSE); diff --git a/linden/indra/llui/llcheckboxctrl.h b/linden/indra/llui/llcheckboxctrl.h index 6aa7113..513b293 100644 --- a/linden/indra/llui/llcheckboxctrl.h +++ b/linden/indra/llui/llcheckboxctrl.h @@ -2,6 +2,8 @@ * @file llcheckboxctrl.h * @brief LLCheckBoxCtrl base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCHECKBOXCTRL_H @@ -91,7 +94,7 @@ public: virtual void setTentative(BOOL b) { mButton->setTentative(b); } virtual BOOL getTentative() const { return mButton->getTentative(); } - virtual BOOL setLabelArg( const LLString& key, const LLString& text ); + virtual BOOL setLabelArg( const LLString& key, const LLStringExplicit& text ); virtual void clear(); virtual void onCommit(); @@ -102,7 +105,7 @@ public: void setEnabledColor( const LLColor4 &color ) { mTextEnabledColor = color; } void setDisabledColor( const LLColor4 &color ) { mTextDisabledColor = color; } - void setLabel( const LLString& label ); + void setLabel( const LLStringExplicit& label ); LLString getLabel() const; virtual void setControlName(const LLString& control_name, LLView* context); diff --git a/linden/indra/llui/llclipboard.cpp b/linden/indra/llui/llclipboard.cpp index 19f0188..fc3967f 100644 --- a/linden/indra/llui/llclipboard.cpp +++ b/linden/indra/llui/llclipboard.cpp @@ -2,6 +2,8 @@ * @file llclipboard.cpp * @brief LLClipboard base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llui/llclipboard.h b/linden/indra/llui/llclipboard.h index dc4cb32..999a17a 100644 --- a/linden/indra/llui/llclipboard.h +++ b/linden/indra/llui/llclipboard.h @@ -2,6 +2,8 @@ * @file llclipboard.h * @brief LLClipboard base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCLIPBOARD_H diff --git a/linden/indra/llui/llcombobox.cpp b/linden/indra/llui/llcombobox.cpp index b71d88f..5f76cfc 100644 --- a/linden/indra/llui/llcombobox.cpp +++ b/linden/indra/llui/llcombobox.cpp @@ -2,6 +2,8 @@ * @file llcombobox.cpp * @brief LLComboBox base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // A control that displays the name of the chosen item, which when @@ -226,12 +229,12 @@ void LLComboBox::clear() { if (mTextEntry) { - mTextEntry->setText(""); + mTextEntry->setText(LLString::null); } - mButton->setLabelSelected(""); - mButton->setLabelUnselected(""); - mButton->setDisabledLabel(""); - mButton->setDisabledSelectedLabel(""); + mButton->setLabelSelected(LLString::null); + mButton->setLabelUnselected(LLString::null); + mButton->setDisabledLabel(LLString::null); + mButton->setDisabledSelectedLabel(LLString::null); mList->deselectAllItems(); } @@ -306,7 +309,7 @@ void LLComboBox::sortByName() // Choose an item with a given name in the menu. // Returns TRUE if the item was found. -BOOL LLComboBox::setSimple(const LLString& name) +BOOL LLComboBox::setSimple(const LLStringExplicit& name) { BOOL found = mList->selectSimpleItem(name, FALSE); @@ -368,7 +371,7 @@ LLSD LLComboBox::getValue() const } } -void LLComboBox::setLabel(const LLString& name) +void LLComboBox::setLabel(const LLStringExplicit& name) { if ( mAllowTextEntry ) { @@ -800,7 +803,7 @@ void LLComboBox::setAllowTextEntry(BOOL allow, S32 max_chars, BOOL set_tentative // clear label on button LLString cur_label = mButton->getLabelSelected(); - setLabel(""); + setLabel(LLString::null); if (!mTextEntry) { LLRect text_entry_rect(0, mRect.getHeight(), mRect.getWidth(), 0); @@ -849,7 +852,7 @@ void LLComboBox::setAllowTextEntry(BOOL allow, S32 max_chars, BOOL set_tentative mTextEntryTentative = set_tentative; } -void LLComboBox::setTextEntry(const LLString& text) +void LLComboBox::setTextEntry(const LLStringExplicit& text) { if (mTextEntry) { diff --git a/linden/indra/llui/llcombobox.h b/linden/indra/llui/llcombobox.h index 1589c30..ff17d28 100644 --- a/linden/indra/llui/llcombobox.h +++ b/linden/indra/llui/llcombobox.h @@ -2,6 +2,8 @@ * @file llcombobox.h * @brief LLComboBox base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // A control that displays the name of the chosen item, which when clicked @@ -102,7 +105,7 @@ public: virtual LLSD getValue() const; void setAllowTextEntry(BOOL allow, S32 max_chars = 50, BOOL make_tentative = TRUE); - void setTextEntry(const LLString& text); + void setTextEntry(const LLStringExplicit& text); void add(const LLString& name, EAddPosition pos = ADD_BOTTOM, BOOL enabled = TRUE); // add item "name" to menu void add(const LLString& name, const LLUUID& id, EAddPosition pos = ADD_BOTTOM, BOOL enabled = TRUE); @@ -114,7 +117,7 @@ public: void sortByName(); // Sort the entries in the combobox by name // Select current item by name using selectSimpleItem. Returns FALSE if not found. - BOOL setSimple(const LLString& name); + BOOL setSimple(const LLStringExplicit& name); // Get name of current item. Returns an empty string if not found. const LLString& getSimple() const; // Get contents of column x of selected row @@ -122,7 +125,7 @@ public: // Sets the label, which doesn't have to exist in the label. // This is probably a UI abuse. - void setLabel(const LLString& name); + void setLabel(const LLStringExplicit& name); BOOL remove(const LLString& name); // remove item "name", return TRUE if found and removed diff --git a/linden/indra/llui/llctrlselectioninterface.cpp b/linden/indra/llui/llctrlselectioninterface.cpp index d3b83a2..3dd4019 100644 --- a/linden/indra/llui/llctrlselectioninterface.cpp +++ b/linden/indra/llui/llctrlselectioninterface.cpp @@ -2,6 +2,8 @@ * @file llctrlselectioninterface.cpp * @brief Programmatic selection of items in a list. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llui/llctrlselectioninterface.h b/linden/indra/llui/llctrlselectioninterface.h index 237aa94..688c0a2 100644 --- a/linden/indra/llui/llctrlselectioninterface.h +++ b/linden/indra/llui/llctrlselectioninterface.h @@ -2,6 +2,8 @@ * @file llctrlselectioninterface.h * @brief Programmatic selection of items in a list. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLCTRLSELECTIONINTERFACE_H diff --git a/linden/indra/llui/lldraghandle.cpp b/linden/indra/llui/lldraghandle.cpp index 3497f0d..ca536ea 100644 --- a/linden/indra/llui/lldraghandle.cpp +++ b/linden/indra/llui/lldraghandle.cpp @@ -2,6 +2,8 @@ * @file lldraghandle.cpp * @brief LLDragHandle base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // A widget for dragging a view around the screen using the mouse. diff --git a/linden/indra/llui/lldraghandle.h b/linden/indra/llui/lldraghandle.h index 691851d..50d199f 100644 --- a/linden/indra/llui/lldraghandle.h +++ b/linden/indra/llui/lldraghandle.h @@ -2,6 +2,8 @@ * @file lldraghandle.h * @brief LLDragHandle base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // A widget for dragging a view around the screen using the mouse. diff --git a/linden/indra/llui/lleditmenuhandler.cpp b/linden/indra/llui/lleditmenuhandler.cpp index 559cef4..9fb9cbe 100644 --- a/linden/indra/llui/lleditmenuhandler.cpp +++ b/linden/indra/llui/lleditmenuhandler.cpp @@ -2,28 +2,31 @@ * @file lleditmenuhandler.cpp * @authors Aaron Yonas, James Cook * +* $LicenseInfo:firstyear=2006&license=viewergpl$ +* * Copyright (c) 2006-2007, Linden Research, Inc. * - * Second Life Viewer Source Code - * The source code in this file ("Source Code") is provided by Linden Lab - * to you under the terms of the GNU General Public License, version 2.0 - * ("GPL"), unless you have obtained a separate licensing agreement - * ("Other License"), formally executed by you and Linden Lab. Terms of - * the GPL can be found in doc/GPL-license.txt in this distribution, or - * online at http://secondlife.com/developers/opensource/gplv2 - * - * There are special exceptions to the terms and conditions of the GPL as - * it is applied to this Source Code. View the full text of the exception - * in the file doc/FLOSS-exception.txt in this software distribution, or - * online at http://secondlife.com/developers/opensource/flossexception - * - * By copying, modifying or distributing this software, you acknowledge - * that you have read and understood your obligations described above, - * and agree to abide by those obligations. - * - * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO - * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, - * COMPLETENESS OR PERFORMANCE. +* Second Life Viewer Source Code +* The source code in this file ("Source Code") is provided by Linden Lab +* to you under the terms of the GNU General Public License, version 2.0 +* ("GPL"), unless you have obtained a separate licensing agreement +* ("Other License"), formally executed by you and Linden Lab. Terms of +* the GPL can be found in doc/GPL-license.txt in this distribution, or +* online at http://secondlife.com/developers/opensource/gplv2 +* +* There are special exceptions to the terms and conditions of the GPL as +* it is applied to this Source Code. View the full text of the exception +* in the file doc/FLOSS-exception.txt in this software distribution, or +* online at http://secondlife.com/developers/opensource/flossexception +* +* By copying, modifying or distributing this software, you acknowledge +* that you have read and understood your obligations described above, +* and agree to abide by those obligations. +* +* ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO +* WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, +* COMPLETENESS OR PERFORMANCE. +* $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llui/lleditmenuhandler.h b/linden/indra/llui/lleditmenuhandler.h index ec3d246..b035a29 100644 --- a/linden/indra/llui/lleditmenuhandler.h +++ b/linden/indra/llui/lleditmenuhandler.h @@ -2,28 +2,31 @@ * @file lleditmenuhandler.h * @authors Aaron Yonas, James Cook * +* $LicenseInfo:firstyear=2006&license=viewergpl$ +* * Copyright (c) 2006-2007, Linden Research, Inc. * - * Second Life Viewer Source Code - * The source code in this file ("Source Code") is provided by Linden Lab - * to you under the terms of the GNU General Public License, version 2.0 - * ("GPL"), unless you have obtained a separate licensing agreement - * ("Other License"), formally executed by you and Linden Lab. Terms of - * the GPL can be found in doc/GPL-license.txt in this distribution, or - * online at http://secondlife.com/developers/opensource/gplv2 - * - * There are special exceptions to the terms and conditions of the GPL as - * it is applied to this Source Code. View the full text of the exception - * in the file doc/FLOSS-exception.txt in this software distribution, or - * online at http://secondlife.com/developers/opensource/flossexception - * - * By copying, modifying or distributing this software, you acknowledge - * that you have read and understood your obligations described above, - * and agree to abide by those obligations. - * - * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO - * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, - * COMPLETENESS OR PERFORMANCE. +* Second Life Viewer Source Code +* The source code in this file ("Source Code") is provided by Linden Lab +* to you under the terms of the GNU General Public License, version 2.0 +* ("GPL"), unless you have obtained a separate licensing agreement +* ("Other License"), formally executed by you and Linden Lab. Terms of +* the GPL can be found in doc/GPL-license.txt in this distribution, or +* online at http://secondlife.com/developers/opensource/gplv2 +* +* There are special exceptions to the terms and conditions of the GPL as +* it is applied to this Source Code. View the full text of the exception +* in the file doc/FLOSS-exception.txt in this software distribution, or +* online at http://secondlife.com/developers/opensource/flossexception +* +* By copying, modifying or distributing this software, you acknowledge +* that you have read and understood your obligations described above, +* and agree to abide by those obligations. +* +* ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO +* WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, +* COMPLETENESS OR PERFORMANCE. +* $/LicenseInfo$ */ #ifndef LLEDITMENUHANDLER_H diff --git a/linden/indra/llui/llfloater.cpp b/linden/indra/llui/llfloater.cpp index 77fddfb..41a67f2 100644 --- a/linden/indra/llui/llfloater.cpp +++ b/linden/indra/llui/llfloater.cpp @@ -2,6 +2,8 @@ * @file llfloater.cpp * @brief LLFloater base class * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Floating "windows" within the GL display, like the inventory floater, diff --git a/linden/indra/llui/llfloater.h b/linden/indra/llui/llfloater.h index baa192a..d0494ea 100644 --- a/linden/indra/llui/llfloater.h +++ b/linden/indra/llui/llfloater.h @@ -2,6 +2,8 @@ * @file llfloater.h * @brief LLFloater base class * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Floating "windows" within the GL display, like the inventory floater, diff --git a/linden/indra/llui/llfocusmgr.cpp b/linden/indra/llui/llfocusmgr.cpp index f9f3350..6358ccb 100644 --- a/linden/indra/llui/llfocusmgr.cpp +++ b/linden/indra/llui/llfocusmgr.cpp @@ -2,6 +2,8 @@ * @file llfocusmgr.cpp * @brief LLFocusMgr base class * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llui/llfocusmgr.h b/linden/indra/llui/llfocusmgr.h index 9b7a84e..1c25153 100644 --- a/linden/indra/llui/llfocusmgr.h +++ b/linden/indra/llui/llfocusmgr.h @@ -2,6 +2,8 @@ * @file llfocusmgr.h * @brief LLFocusMgr base class * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Singleton that manages keyboard and mouse focus diff --git a/linden/indra/llui/llhtmlhelp.h b/linden/indra/llui/llhtmlhelp.h index 4b2a43a..816d0dd 100644 --- a/linden/indra/llui/llhtmlhelp.h +++ b/linden/indra/llui/llhtmlhelp.h @@ -2,6 +2,8 @@ * @file llhtmlhelp.h * @brief HTML Help floater interface * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLHTMLHELP_H diff --git a/linden/indra/llui/lliconctrl.cpp b/linden/indra/llui/lliconctrl.cpp index 2d3071b..1e49210 100644 --- a/linden/indra/llui/lliconctrl.cpp +++ b/linden/indra/llui/lliconctrl.cpp @@ -2,6 +2,8 @@ * @file lliconctrl.cpp * @brief LLIconCtrl base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llui/lliconctrl.h b/linden/indra/llui/lliconctrl.h index 8dbe6db..b789269 100644 --- a/linden/indra/llui/lliconctrl.h +++ b/linden/indra/llui/lliconctrl.h @@ -2,6 +2,8 @@ * @file lliconctrl.h * @brief LLIconCtrl base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLICONCTRL_H diff --git a/linden/indra/llui/llkeywords.cpp b/linden/indra/llui/llkeywords.cpp index 8997bd6..5efb8be 100644 --- a/linden/indra/llui/llkeywords.cpp +++ b/linden/indra/llui/llkeywords.cpp @@ -2,6 +2,8 @@ * @file llkeywords.cpp * @brief Keyword list for LSL * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llui/llkeywords.h b/linden/indra/llui/llkeywords.h index 040df53..4309f16 100644 --- a/linden/indra/llui/llkeywords.h +++ b/linden/indra/llui/llkeywords.h @@ -2,6 +2,8 @@ * @file llkeywords.h * @brief Keyword list for LSL * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLKEYWORDS_H diff --git a/linden/indra/llui/lllineeditor.cpp b/linden/indra/llui/lllineeditor.cpp index dca62d7..9671065 100644 --- a/linden/indra/llui/lllineeditor.cpp +++ b/linden/indra/llui/lllineeditor.cpp @@ -2,6 +2,8 @@ * @file lllineeditor.cpp * @brief LLLineEditor base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Text editor widget to let users enter a single line. @@ -155,7 +158,8 @@ LLLineEditor::LLLineEditor(const LLString& name, const LLRect& rect, mHandleEditKeysDirectly( FALSE ), mSelectAllonFocusReceived( FALSE ), mPassDelete(FALSE), - mReadOnly(FALSE) + mReadOnly(FALSE), + mLastIMEPosition( -1, -1 ) { llassert( max_length_bytes > 0 ); @@ -316,12 +320,12 @@ void LLLineEditor::setBorderWidth(S32 left, S32 right) mMaxHPixels = mRect.getWidth() - mMinHPixels - mBorderThickness - mBorderRight; } -void LLLineEditor::setLabel(const LLString &new_label) +void LLLineEditor::setLabel(const LLStringExplicit &new_label) { mLabel = new_label; } -void LLLineEditor::setText(const LLString &new_text) +void LLLineEditor::setText(const LLStringExplicit &new_text) { // If new text is identical, don't copy and don't move insertion point if (mText.getString() == new_text) @@ -1629,6 +1633,17 @@ void LLLineEditor::draw() LLFontGL::NORMAL, 1); } + + // Make sure the IME is in the right place + S32 pixels_after_scroll = findPixelNearestPos(); // RCalculcate for IME position + LLRect screen_pos = getScreenRect(); + LLCoordGL ime_pos( screen_pos.mLeft + pixels_after_scroll, screen_pos.mTop - UI_LINEEDITOR_V_PAD ); + if ( ime_pos.mX != mLastIMEPosition.mX || ime_pos.mY != mLastIMEPosition.mY ) + { + mLastIMEPosition.mX = ime_pos.mX; + mLastIMEPosition.mY = ime_pos.mY; + getWindow()->setLanguageTextInput( ime_pos ); + } } } @@ -1792,7 +1807,7 @@ BOOL LLLineEditor::prevalidateFloat(const LLWString &str) for( ; i < len; i++ ) { - if( (decimal_point != trimmed[i] ) && !isdigit( trimmed[i] ) ) + if( (decimal_point != trimmed[i] ) && !LLStringOps::isDigit( trimmed[i] ) ) { success = FALSE; break; @@ -1847,7 +1862,7 @@ BOOL LLLineEditor::postvalidateFloat(const LLString &str) } } else - if( isdigit( trimmed[i] ) ) + if( LLStringOps::isDigit( trimmed[i] ) ) { has_digit = TRUE; } @@ -1890,7 +1905,7 @@ BOOL LLLineEditor::prevalidateInt(const LLWString &str) for( ; i < len; i++ ) { - if( !isdigit( trimmed[i] ) ) + if( !LLStringOps::isDigit( trimmed[i] ) ) { success = FALSE; break; @@ -1919,7 +1934,7 @@ BOOL LLLineEditor::prevalidatePositiveS32(const LLWString &str) S32 i = 0; while(success && (i < len)) { - if(!isdigit(trimmed[i++])) + if(!LLStringOps::isDigit(trimmed[i++])) { success = FALSE; } @@ -1953,7 +1968,7 @@ BOOL LLLineEditor::prevalidateNonNegativeS32(const LLWString &str) S32 i = 0; while(success && (i < len)) { - if(!isdigit(trimmed[i++])) + if(!LLStringOps::isDigit(trimmed[i++])) { success = FALSE; } @@ -2307,13 +2322,13 @@ LLSD LLLineEditor::getValue() const return ret; } -BOOL LLLineEditor::setTextArg( const LLString& key, const LLString& text ) +BOOL LLLineEditor::setTextArg( const LLString& key, const LLStringExplicit& text ) { mText.setArg(key, text); return TRUE; } -BOOL LLLineEditor::setLabelArg( const LLString& key, const LLString& text ) +BOOL LLLineEditor::setLabelArg( const LLString& key, const LLStringExplicit& text ) { mLabel.setArg(key, text); return TRUE; @@ -2338,8 +2353,7 @@ LLSearchEditor::LLSearchEditor(const LLString& name, onSearchEdit, NULL, this); - // TODO: this should be translatable - mSearchEdit->setLabel("Type here to search"); + mSearchEdit->setFollowsAll(); mSearchEdit->setSelectAllonFocusReceived(TRUE); @@ -2394,13 +2408,13 @@ LLSD LLSearchEditor::getValue() const } //virtual -BOOL LLSearchEditor::setTextArg( const LLString& key, const LLString& text ) +BOOL LLSearchEditor::setTextArg( const LLString& key, const LLStringExplicit& text ) { return mSearchEdit->setTextArg(key, text); } //virtual -BOOL LLSearchEditor::setLabelArg( const LLString& key, const LLString& text ) +BOOL LLSearchEditor::setLabelArg( const LLString& key, const LLStringExplicit& text ) { return mSearchEdit->setLabelArg(key, text); } @@ -2422,7 +2436,7 @@ void LLSearchEditor::draw() LLUICtrl::draw(); } -void LLSearchEditor::setText(const LLString &new_text) +void LLSearchEditor::setText(const LLStringExplicit &new_text) { mSearchEdit->setText(new_text); } @@ -2468,6 +2482,12 @@ LLView* LLSearchEditor::fromXML(LLXMLNodePtr node, LLView *parent, LLUICtrlFacto max_text_length, NULL, NULL); + LLString label; + if(node->getAttributeString("label", label)) + { + search_editor->mSearchEdit->setLabel(label); + } + search_editor->setText(text); search_editor->initFromXML(node, parent); diff --git a/linden/indra/llui/lllineeditor.h b/linden/indra/llui/lllineeditor.h index 04c53b4..2cd2ebf 100644 --- a/linden/indra/llui/lllineeditor.h +++ b/linden/indra/llui/lllineeditor.h @@ -2,6 +2,8 @@ * @file lllineeditor.h * @brief LLLineEditor base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Text editor widget to let users enter/edit a single line. @@ -133,11 +136,11 @@ public: // assumes UTF8 text virtual void setValue(const LLSD& value ); virtual LLSD getValue() const; - virtual BOOL setTextArg( const LLString& key, const LLString& text ); - virtual BOOL setLabelArg( const LLString& key, const LLString& text ); + virtual BOOL setTextArg( const LLString& key, const LLStringExplicit& text ); + virtual BOOL setLabelArg( const LLString& key, const LLStringExplicit& text ); - void setLabel(const LLString &new_label); - void setText(const LLString &new_text); + void setLabel(const LLStringExplicit &new_label); + void setText(const LLStringExplicit &new_text); const LLString& getText() const { return mText.getString(); } const LLWString& getWText() const { return mText.getWString(); } @@ -276,6 +279,8 @@ protected: S32 mBorderThickness; + LLCoordGL mLastIMEPosition; // Last screen position used for the IME editor + BOOL mIgnoreArrowKeys; BOOL mIgnoreTab; BOOL mDrawAsterixes; @@ -307,15 +312,15 @@ public: virtual LLString getWidgetTag() const; static LLView* fromXML(LLXMLNodePtr node, LLView *parent, LLUICtrlFactory *factory); - void setText(const LLString &new_text); + void setText(const LLStringExplicit &new_text); void setSearchCallback(void (*search_callback)(const LLString& search_string, void* user_data), void* data) { mSearchCallback = search_callback; mCallbackUserData = data; } // LLUICtrl interface virtual void setValue(const LLSD& value ); virtual LLSD getValue() const; - virtual BOOL setTextArg( const LLString& key, const LLString& text ); - virtual BOOL setLabelArg( const LLString& key, const LLString& text ); + virtual BOOL setTextArg( const LLString& key, const LLStringExplicit& text ); + virtual BOOL setLabelArg( const LLString& key, const LLStringExplicit& text ); virtual void clear(); diff --git a/linden/indra/llui/llmemberlistener.h b/linden/indra/llui/llmemberlistener.h index bc67519..b6f6b3c 100644 --- a/linden/indra/llui/llmemberlistener.h +++ b/linden/indra/llui/llmemberlistener.h @@ -2,6 +2,8 @@ * @file llmemberlistener.h * @brief Listener class which registers itself with its parent view * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMEMBERLISTENER_H @@ -36,7 +39,7 @@ template class LLMemberListener : public LLSimpleListener { public: - LLMemberListener() : mPtr(NULL), mRegisteredName("") { } + LLMemberListener() : mPtr(NULL), mRegisteredName() { } void registerListener(T *pointer, const LLString& register_name) { diff --git a/linden/indra/llui/llmenugl.cpp b/linden/indra/llui/llmenugl.cpp index b0d2d9f..5d2a052 100644 --- a/linden/indra/llui/llmenugl.cpp +++ b/linden/indra/llui/llmenugl.cpp @@ -2,6 +2,8 @@ * @file llmenugl.cpp * @brief LLMenuItemGL base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //***************************************************************************** @@ -370,7 +373,7 @@ void LLMenuItemGL::setHighlightFGColor( const LLColor4& color ) // change the label -void LLMenuItemGL::setLabel( const LLString& label ) +void LLMenuItemGL::setLabel( const LLStringExplicit& label ) { mLabel = label; } @@ -595,7 +598,7 @@ void LLMenuItemGL::draw( void ) mGotHover = FALSE; } -BOOL LLMenuItemGL::setLabelArg( const LLString& key, const LLString& text ) +BOOL LLMenuItemGL::setLabelArg( const LLString& key, const LLStringExplicit& text ) { mLabel.setArg(key, text); return TRUE; @@ -1236,6 +1239,7 @@ BOOL LLMenuItemBranchGL::handleMouseUp(S32 x, S32 y, MASK mask) doIt(); make_ui_sound("UISndClickRelease"); + return TRUE; } return FALSE; } @@ -1547,7 +1551,7 @@ public: // LLView functionality virtual BOOL handleMouseDown( S32 x, S32 y, MASK mask ); - virtual BOOL handleMouseUp( S32 x, S32 y, MASK mask ) {return FALSE; } + virtual BOOL handleMouseUp( S32 x, S32 y, MASK mask ); virtual void draw( void ); virtual BOOL handleKeyHere(KEY key, MASK mask, BOOL called_from_parent); @@ -1671,6 +1675,11 @@ BOOL LLMenuItemBranchDownGL::handleMouseDown( S32 x, S32 y, MASK mask ) return TRUE; } +BOOL LLMenuItemBranchDownGL::handleMouseUp( S32 x, S32 y, MASK mask ) +{ + return TRUE; +} + BOOL LLMenuItemBranchDownGL::handleAcceleratorKey(KEY key, MASK mask) { diff --git a/linden/indra/llui/llmenugl.h b/linden/indra/llui/llmenugl.h index 6051a26..6dc9282 100644 --- a/linden/indra/llui/llmenugl.h +++ b/linden/indra/llui/llmenugl.h @@ -2,6 +2,8 @@ * @file llmenugl.h * @brief Declaration of the opengl based menu system. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMENUGL_H @@ -124,8 +127,8 @@ public: LLString getLabel( void ) const { return mLabel.getString(); } // change the label - void setLabel( const LLString& label ); - virtual BOOL setLabelArg( const LLString& key, const LLString& text ); + void setLabel( const LLStringExplicit& label ); + virtual BOOL setLabelArg( const LLString& key, const LLStringExplicit& text ); // Get the parent menu for this item virtual LLMenuGL* getMenu(); @@ -440,7 +443,7 @@ public: // return the name label const LLString& getLabel( void ) const { return mLabel.getString(); } - void setLabel(const LLString& label) { mLabel = label; } + void setLabel(const LLStringExplicit& label) { mLabel = label; } static void setDefaultBackgroundColor( const LLColor4& color ); void setBackgroundColor( const LLColor4& color ); diff --git a/linden/indra/llui/llmodaldialog.cpp b/linden/indra/llui/llmodaldialog.cpp index 788dead..b8b8bf9 100644 --- a/linden/indra/llui/llmodaldialog.cpp +++ b/linden/indra/llui/llmodaldialog.cpp @@ -2,6 +2,8 @@ * @file llmodaldialog.cpp * @brief LLModalDialog base class * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llui/llmodaldialog.h b/linden/indra/llui/llmodaldialog.h index c2564af..2355861 100644 --- a/linden/indra/llui/llmodaldialog.h +++ b/linden/indra/llui/llmodaldialog.h @@ -2,6 +2,8 @@ * @file llmodaldialog.h * @brief LLModalDialog base class * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMODALDIALOG_H diff --git a/linden/indra/llui/llpanel.cpp b/linden/indra/llui/llpanel.cpp index 91a327b..3a0ee9b 100644 --- a/linden/indra/llui/llpanel.cpp +++ b/linden/indra/llui/llpanel.cpp @@ -2,6 +2,8 @@ * @file llpanel.cpp * @brief LLPanel base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Opaque view with a background and a border. Can contain LLUICtrls. @@ -959,7 +962,7 @@ LLSD LLPanel::childGetValue(const LLString& id) const return LLSD(); } -BOOL LLPanel::childSetTextArg(const LLString& id, const LLString& key, const LLString& text) +BOOL LLPanel::childSetTextArg(const LLString& id, const LLString& key, const LLStringExplicit& text) { LLUICtrl* child = (LLUICtrl*)getChildByName(id, true); if (child) @@ -969,7 +972,7 @@ BOOL LLPanel::childSetTextArg(const LLString& id, const LLString& key, const LLS return FALSE; } -BOOL LLPanel::childSetLabelArg(const LLString& id, const LLString& key, const LLString& text) +BOOL LLPanel::childSetLabelArg(const LLString& id, const LLString& key, const LLStringExplicit& text) { LLView* child = getChildByName(id, true); if (child) @@ -1030,7 +1033,7 @@ void LLPanel::childSetTabChangeCallback(const LLString& id, const LLString& tabn } } -void LLPanel::childSetText(const LLString& id, const LLString& text) +void LLPanel::childSetText(const LLString& id, const LLStringExplicit& text) { childSetValue(id, LLSD(text)); } @@ -1103,7 +1106,7 @@ void LLPanel::childSetControlName(const LLString& id, const LLString& control_na LLView* LLPanel::getChildByName(const LLString& name, BOOL recurse) const { LLView* view = LLUICtrl::getChildByName(name, recurse); - if (!view) + if (!view && !recurse) { childNotFound(name); } @@ -1293,9 +1296,9 @@ LLView* LLLayoutStack::fromXML(LLXMLNodePtr node, LLView *parent, LLUICtrlFactor child->getAttributeBOOL("auto_resize", auto_resize); LLPanel* panelp = (LLPanel*)LLPanel::fromXML(child, layout_stackp, factory); - panelp->setFollowsNone(); if (panelp) { + panelp->setFollowsNone(); layout_stackp->addPanel(panelp, min_width, min_height, auto_resize); } } diff --git a/linden/indra/llui/llpanel.h b/linden/indra/llui/llpanel.h index 28c56fa..dfd7a51 100644 --- a/linden/indra/llui/llpanel.h +++ b/linden/indra/llui/llpanel.h @@ -3,6 +3,8 @@ * @author James Cook, Tom Yedwab * @brief LLPanel base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANEL_H @@ -116,7 +119,7 @@ public: void setBackgroundOpaque(BOOL b) { mBgOpaque = b; } void setDefaultBtn(LLButton* btn = NULL); void setDefaultBtn(const LLString& id); - void setLabel(LLString label) { mLabel = label; } + void setLabel(const LLStringExplicit& label) { mLabel = label; } LLString getLabel() const { return mLabel; } void setRectControl(const LLString& rect_control) { mRectControl.assign(rect_control); } @@ -189,8 +192,8 @@ public: // For setting text / label replacement params, e.g. "Hello [NAME]" // Not implemented for all types, defaults to noop, returns FALSE if not applicaple - BOOL childSetTextArg(const LLString& id, const LLString& key, const LLString& text); - BOOL childSetLabelArg(const LLString& id, const LLString& key, const LLString& text); + BOOL childSetTextArg(const LLString& id, const LLString& key, const LLStringExplicit& text); + BOOL childSetLabelArg(const LLString& id, const LLString& key, const LLStringExplicit& text); // LLSlider / LLSpinCtrl void childSetMinValue(const LLString& id, LLSD min_value); @@ -205,7 +208,7 @@ public: void childSetWrappedText(const LLString& id, const LLString& text, bool visible = true); // LLTextBox/LLTextEditor/LLLineEditor - void childSetText(const LLString& id, const LLString& text); + void childSetText(const LLString& id, const LLStringExplicit& text); LLString childGetText(const LLString& id); // LLLineEditor diff --git a/linden/indra/llui/llradiogroup.cpp b/linden/indra/llui/llradiogroup.cpp index 0104998..5b9a353 100644 --- a/linden/indra/llui/llradiogroup.cpp +++ b/linden/indra/llui/llradiogroup.cpp @@ -2,6 +2,8 @@ * @file llradiogroup.cpp * @brief LLRadioGroup base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // An invisible view containing multiple mutually exclusive toggling diff --git a/linden/indra/llui/llradiogroup.h b/linden/indra/llui/llradiogroup.h index 5b3e4db..aa19b3a 100644 --- a/linden/indra/llui/llradiogroup.h +++ b/linden/indra/llui/llradiogroup.h @@ -2,6 +2,8 @@ * @file llradiogroup.h * @brief LLRadioGroup base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // An invisible view containing multiple mutually exclusive toggling diff --git a/linden/indra/llui/llresizebar.cpp b/linden/indra/llui/llresizebar.cpp index f716e8e..ac8c47c 100644 --- a/linden/indra/llui/llresizebar.cpp +++ b/linden/indra/llui/llresizebar.cpp @@ -2,6 +2,8 @@ * @file llresizebar.cpp * @brief LLResizeBar base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llui/llresizebar.h b/linden/indra/llui/llresizebar.h index d3596ec..d040a8b 100644 --- a/linden/indra/llui/llresizebar.h +++ b/linden/indra/llui/llresizebar.h @@ -2,6 +2,8 @@ * @file llresizebar.h * @brief LLResizeBar base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_RESIZEBAR_H diff --git a/linden/indra/llui/llresizehandle.cpp b/linden/indra/llui/llresizehandle.cpp index d9b8fac..17b76de 100644 --- a/linden/indra/llui/llresizehandle.cpp +++ b/linden/indra/llui/llresizehandle.cpp @@ -2,6 +2,8 @@ * @file llresizehandle.cpp * @brief LLResizeHandle base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llui/llresizehandle.h b/linden/indra/llui/llresizehandle.h index b091f1f..2701613 100644 --- a/linden/indra/llui/llresizehandle.h +++ b/linden/indra/llui/llresizehandle.h @@ -2,6 +2,8 @@ * @file llresizehandle.h * @brief LLResizeHandle base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_RESIZEHANDLE_H diff --git a/linden/indra/llui/llresmgr.cpp b/linden/indra/llui/llresmgr.cpp index 5ed2cb3..e77faa9 100644 --- a/linden/indra/llui/llresmgr.cpp +++ b/linden/indra/llui/llresmgr.cpp @@ -2,6 +2,8 @@ * @file llresmgr.cpp * @brief Localized resource manager * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // NOTE: this is a MINIMAL implementation. The interface will remain, but the implementation will diff --git a/linden/indra/llui/llresmgr.h b/linden/indra/llui/llresmgr.h index 836d352..d9e58bc 100644 --- a/linden/indra/llui/llresmgr.h +++ b/linden/indra/llui/llresmgr.h @@ -2,6 +2,8 @@ * @file llresmgr.h * @brief Localized resource manager * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // NOTE: this is a MINIMAL implementation. The interface will remain, but the implementation will diff --git a/linden/indra/llui/llrootview.cpp b/linden/indra/llui/llrootview.cpp index bf231f1..5973e4c 100644 --- a/linden/indra/llui/llrootview.cpp +++ b/linden/indra/llui/llrootview.cpp @@ -2,6 +2,8 @@ * @file llrootview.cpp * @brief Container for all other views in an application * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llui/llrootview.h b/linden/indra/llui/llrootview.h index ce98006..aedf02c 100644 --- a/linden/indra/llui/llrootview.h +++ b/linden/indra/llui/llrootview.h @@ -2,6 +2,8 @@ * @file llrootview.h * @brief Container for all other views in an application * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLROOTVIEW_H diff --git a/linden/indra/llui/llscrollbar.cpp b/linden/indra/llui/llscrollbar.cpp index 4edf81e..99908a6 100644 --- a/linden/indra/llui/llscrollbar.cpp +++ b/linden/indra/llui/llscrollbar.cpp @@ -2,6 +2,8 @@ * @file llscrollbar.cpp * @brief Scrollbar UI widget * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llui/llscrollbar.h b/linden/indra/llui/llscrollbar.h index f6ac17d..353935c 100644 --- a/linden/indra/llui/llscrollbar.h +++ b/linden/indra/llui/llscrollbar.h @@ -2,6 +2,8 @@ * @file llscrollbar.h * @brief Scrollbar UI widget * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_SCROLLBAR_H diff --git a/linden/indra/llui/llscrollcontainer.cpp b/linden/indra/llui/llscrollcontainer.cpp index b910964..8b5d009 100644 --- a/linden/indra/llui/llscrollcontainer.cpp +++ b/linden/indra/llui/llscrollcontainer.cpp @@ -2,6 +2,8 @@ * @file llscrollcontainer.cpp * @brief LLScrollableContainerView base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //***************************************************************************** diff --git a/linden/indra/llui/llscrollcontainer.h b/linden/indra/llui/llscrollcontainer.h index 34fff9c..9f1978b 100644 --- a/linden/indra/llui/llscrollcontainer.h +++ b/linden/indra/llui/llscrollcontainer.h @@ -2,6 +2,8 @@ * @file llscrollcontainer.h * @brief LLScrollableContainerView class header file. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSCROLLCONTAINER_H diff --git a/linden/indra/llui/llscrollingpanellist.cpp b/linden/indra/llui/llscrollingpanellist.cpp index eb806e4..76389e1 100644 --- a/linden/indra/llui/llscrollingpanellist.cpp +++ b/linden/indra/llui/llscrollingpanellist.cpp @@ -2,6 +2,8 @@ * @file llscrollingpanellist.cpp * @brief * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llui/llscrollingpanellist.h b/linden/indra/llui/llscrollingpanellist.h index 29e3d41..f697a99 100644 --- a/linden/indra/llui/llscrollingpanellist.h +++ b/linden/indra/llui/llscrollingpanellist.h @@ -1,6 +1,8 @@ /** * @file llscrollingpanellist.h * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include diff --git a/linden/indra/llui/llscrolllistctrl.cpp b/linden/indra/llui/llscrolllistctrl.cpp index 9e1a573..f5eef29 100644 --- a/linden/indra/llui/llscrolllistctrl.cpp +++ b/linden/indra/llui/llscrolllistctrl.cpp @@ -2,6 +2,8 @@ * @file llscrolllistctrl.cpp * @brief LLScrollListCtrl base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include @@ -229,7 +232,7 @@ void LLScrollListText::setColor(const LLColor4& color) *mColor = color; } -void LLScrollListText::setText(const LLString& text) +void LLScrollListText::setText(const LLStringExplicit& text) { mText = text; } @@ -620,6 +623,7 @@ std::vector LLScrollListCtrl::getAllData() const void LLScrollListCtrl::reshape( S32 width, S32 height, BOOL called_from_parent ) { + S32 old_height = mRect.getHeight(); LLUICtrl::reshape( width, height, called_from_parent ); S32 heading_size = (mDisplayColumnHeaders ? mHeadingHeight : 0); @@ -631,9 +635,13 @@ void LLScrollListCtrl::reshape( S32 width, S32 height, BOOL called_from_parent ) mRect.getHeight() - 2*( mBorderThickness + LIST_BORDER_PAD ) - heading_size ); mPageLines = mLineHeight? mItemListRect.getHeight() / mLineHeight : 0; + if(old_height < height && getScrollPos() == mScrollbar->getDocPosMax()) + { + setScrollPos(mScrollbar->getDocPosMax()); + } mScrollbar->setVisible(mPageLines < getItemCount()); mScrollbar->setPageSize( mPageLines ); - + updateColumns(); } @@ -770,6 +778,7 @@ void LLScrollListCtrl::updateColumns() mColumnsIndexed.resize(mColumns.size()); std::map::iterator column_itor; + bool first_dynamic = true; for (column_itor = mColumns.begin(); column_itor != mColumns.end(); ++column_itor) { LLScrollListColumn *column = &column_itor->second; @@ -781,6 +790,11 @@ void LLScrollListCtrl::updateColumns() else if (column->mDynamicWidth) { new_width = (mItemListRect.getWidth() - mTotalStaticColumnWidth) / mNumDynamicWidthColumns; + if(first_dynamic) + { + first_dynamic = false; + new_width += (mScrollbar->getVisible() ? 0 : SCROLLBAR_SIZE); + } } if (new_width != column->mWidth) @@ -810,9 +824,10 @@ void LLScrollListCtrl::updateColumns() LLColumnHeader* last_header = NULL; for (column_ordered_it = mColumnsIndexed.begin(); column_ordered_it != mColumnsIndexed.end(); ++column_ordered_it) { - if ((*column_ordered_it)->mWidth <= 0) + if ((*column_ordered_it)->mWidth < 0) { - // skip hidden columns + // skip hidden columns + continue; } LLScrollListColumn* column = *column_ordered_it; @@ -827,9 +842,8 @@ void LLScrollListCtrl::updateColumns() right += mColumnPadding; } right = llmax(left, llmin(mItemListRect.getWidth(), right)); - S32 header_width = right - left; - + last_header->reshape(header_width, mHeadingHeight); last_header->translate(left - last_header->getRect().mLeft, top - last_header->getRect().mBottom); last_header->setVisible(mDisplayColumnHeaders && header_width > 0); @@ -838,12 +852,15 @@ void LLScrollListCtrl::updateColumns() } // expand last column header we encountered to full list width + if (last_header) { S32 header_strip_width = mItemListRect.getWidth() + (mScrollbar->getVisible() ? 0 : SCROLLBAR_SIZE); S32 new_width = llmax(0, mItemListRect.mLeft + header_strip_width - last_header->getRect().mLeft); last_header->reshape(new_width, last_header->getRect().getHeight()); + last_header->setVisible(mDisplayColumnHeaders && new_width > 0); } + } void LLScrollListCtrl::setDisplayHeading(BOOL display) @@ -1453,7 +1470,9 @@ void LLScrollListCtrl::drawItems() LLGLSUIDefault gls_ui; { - LLLocalClipRect clip(mItemListRect); + LLRect clip_rect = mItemListRect; + if(!mScrollbar->getVisible()) clip_rect.mRight += SCROLLBAR_SIZE; + LLLocalClipRect clip(clip_rect); S32 cur_x = x; S32 cur_y = y; @@ -1472,10 +1491,10 @@ void LLScrollListCtrl::drawItems() item_rect.setOriginAndSize( cur_x, cur_y, - mScrollbar->getVisible() ? mItemListRect.getWidth() : mItemListRect.getWidth() + mScrollbar->getRect().getWidth(), + mScrollbar->getVisible() ? mItemListRect.getWidth() : mItemListRect.getWidth() + SCROLLBAR_SIZE, mLineHeight ); - lldebugs << mItemListRect.getWidth() << llendl; + //llinfos << item_rect.getWidth() << llendl; if (item->getSelected()) { @@ -1523,22 +1542,31 @@ void LLScrollListCtrl::drawItems() S32 cur_col = 0; S32 dynamic_width = 0; S32 dynamic_remainder = 0; + bool first_dynamic = true; if(mNumDynamicWidthColumns > 0) { dynamic_width = (mItemListRect.getWidth() - mTotalStaticColumnWidth) / mNumDynamicWidthColumns; dynamic_remainder = (mItemListRect.getWidth() - mTotalStaticColumnWidth) % mNumDynamicWidthColumns; } + for (LLScrollListCell* cell = item->getColumn(0); cur_col < num_cols; cell = item->getColumn(++cur_col)) { S32 cell_width = cell->getWidth(); + if(mColumnsIndexed.size() > (U32)cur_col && mColumnsIndexed[cur_col] && mColumnsIndexed[cur_col]->mDynamicWidth) { cell_width = dynamic_width + (--dynamic_remainder ? 1 : 0); + if(first_dynamic) + { + cell_width += mScrollbar->getVisible() ? 0 : SCROLLBAR_SIZE; + first_dynamic = false; + } cell->setWidth(cell_width); } // Two ways a cell could be hidden if (cell_width < 0 || !cell->getVisible()) continue; + LLUI::pushMatrix(); LLUI::translate((F32) cur_x, (F32) cur_y, 0.0f); S32 space_left = mItemListRect.mRight - cur_x; diff --git a/linden/indra/llui/llscrolllistctrl.h b/linden/indra/llui/llscrolllistctrl.h index 2e4dad5..5ceee2e 100644 --- a/linden/indra/llui/llscrolllistctrl.h +++ b/linden/indra/llui/llscrolllistctrl.h @@ -2,6 +2,8 @@ * @file llscrolllistctrl.h * @brief LLScrollListCtrl base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_SCROLLLISTCTRL_H @@ -98,7 +101,7 @@ public: virtual const LLString& getText() const { return mText.getString(); } virtual BOOL getVisible() const { return mVisible; } virtual void highlightText(S32 offset, S32 num_chars) {mHighlightOffset = offset; mHighlightCount = num_chars;} - void setText(const LLString& text); + void setText(const LLStringExplicit& text); virtual void setColor(const LLColor4&); virtual BOOL isText() { return TRUE; } @@ -166,10 +169,10 @@ class LLScrollListColumn public: // Default constructor LLScrollListColumn() : - mName(""), - mSortingColumn(""), - mSortAscending(TRUE), - mLabel(""), + mName(), + mSortingColumn(), + mSortAscending(TRUE), + mLabel(), mWidth(-1), mRelWidth(-1.0), mDynamicWidth(FALSE), diff --git a/linden/indra/llui/llslider.cpp b/linden/indra/llui/llslider.cpp index e3a3153..29626c2 100644 --- a/linden/indra/llui/llslider.cpp +++ b/linden/indra/llui/llslider.cpp @@ -2,6 +2,8 @@ * @file llslider.cpp * @brief LLSlider base class * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llui/llslider.h b/linden/indra/llui/llslider.h index 8fcd672..2641eaa 100644 --- a/linden/indra/llui/llslider.h +++ b/linden/indra/llui/llslider.h @@ -2,6 +2,8 @@ * @file llslider.h * @brief A simple slider with no label. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSLIDER_H diff --git a/linden/indra/llui/llsliderctrl.cpp b/linden/indra/llui/llsliderctrl.cpp index dff27cc..dd4a994 100644 --- a/linden/indra/llui/llsliderctrl.cpp +++ b/linden/indra/llui/llsliderctrl.cpp @@ -2,6 +2,8 @@ * @file llsliderctrl.cpp * @brief LLSliderCtrl base class * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -167,7 +170,7 @@ void LLSliderCtrl::setValue(F32 v, BOOL from_event) updateText(); } -BOOL LLSliderCtrl::setLabelArg( const LLString& key, const LLString& text ) +BOOL LLSliderCtrl::setLabelArg( const LLString& key, const LLStringExplicit& text ) { BOOL res = FALSE; if (mLabelBox) @@ -197,11 +200,11 @@ void LLSliderCtrl::clear() setValue(0.0f); if( mEditor ) { - mEditor->setText( "" ); + mEditor->setText( LLString::null ); } if( mTextBox ) { - mTextBox->setText( "" ); + mTextBox->setText( LLString::null ); } } diff --git a/linden/indra/llui/llsliderctrl.h b/linden/indra/llui/llsliderctrl.h index 6896360..fa6c0bc 100644 --- a/linden/indra/llui/llsliderctrl.h +++ b/linden/indra/llui/llsliderctrl.h @@ -2,6 +2,8 @@ * @file llsliderctrl.h * @brief LLSliderCtrl base class * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSLIDERCTRL_H @@ -77,7 +80,7 @@ public: virtual void setValue(const LLSD& value ) { setValue((F32)value.asReal(), TRUE); } virtual LLSD getValue() const { return LLSD(getValueF32()); } - virtual BOOL setLabelArg( const LLString& key, const LLString& text ); + virtual BOOL setLabelArg( const LLString& key, const LLStringExplicit& text ); virtual void setMinValue(LLSD min_value) { setMinValue((F32)min_value.asReal()); } virtual void setMaxValue(LLSD max_value) { setMaxValue((F32)max_value.asReal()); } @@ -94,7 +97,7 @@ public: F32 getMinValue() { return mSlider->getMinValue(); } F32 getMaxValue() { return mSlider->getMaxValue(); } - void setLabel(const LLString& label) { if (mLabelBox) mLabelBox->setText(label); } + void setLabel(const LLStringExplicit& label) { if (mLabelBox) mLabelBox->setText(label); } void setLabelColor(const LLColor4& c) { mTextEnabledColor = c; } void setDisabledLabelColor(const LLColor4& c) { mTextDisabledColor = c; } diff --git a/linden/indra/llui/llspinctrl.cpp b/linden/indra/llui/llspinctrl.cpp index f587c80..2be2814 100644 --- a/linden/indra/llui/llspinctrl.cpp +++ b/linden/indra/llui/llspinctrl.cpp @@ -2,6 +2,8 @@ * @file llspinctrl.cpp * @brief LLSpinCtrl base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -382,7 +385,7 @@ void LLSpinCtrl::setPrecision(S32 precision) updateEditor(); } -void LLSpinCtrl::setLabel(const LLString& label) +void LLSpinCtrl::setLabel(const LLStringExplicit& label) { if (mLabelBox) { diff --git a/linden/indra/llui/llspinctrl.h b/linden/indra/llui/llspinctrl.h index c854ff0..f2c7b40 100644 --- a/linden/indra/llui/llspinctrl.h +++ b/linden/indra/llui/llspinctrl.h @@ -2,6 +2,8 @@ * @file llspinctrl.h * @brief LLSpinCtrl base class * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSPINCTRL_H @@ -93,7 +96,7 @@ public: virtual void setMaxValue(F32 max) { mMaxValue = max; } virtual void setIncrement(F32 inc) { mIncrement = inc; } - void setLabel(const LLString& label); + void setLabel(const LLStringExplicit& label); void setLabelColor(const LLColor4& c) { mTextEnabledColor = c; } void setDisabledLabelColor(const LLColor4& c) { mTextDisabledColor = c; } diff --git a/linden/indra/llui/llstyle.cpp b/linden/indra/llui/llstyle.cpp index 1efb4cc..1f932f7 100644 --- a/linden/indra/llui/llstyle.cpp +++ b/linden/indra/llui/llstyle.cpp @@ -2,6 +2,8 @@ * @file llstyle.cpp * @brief Text style class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llui/llstyle.h b/linden/indra/llui/llstyle.h index e6e88e7..809253f 100644 --- a/linden/indra/llui/llstyle.h +++ b/linden/indra/llui/llstyle.h @@ -2,6 +2,8 @@ * @file llstyle.h * @brief Text style class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSTYLE_H diff --git a/linden/indra/llui/lltabcontainer.cpp b/linden/indra/llui/lltabcontainer.cpp index 135931d..1ab11f3 100644 --- a/linden/indra/llui/lltabcontainer.cpp +++ b/linden/indra/llui/lltabcontainer.cpp @@ -2,6 +2,8 @@ * @file lltabcontainer.cpp * @brief LLTabContainerCommon base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llui/lltabcontainer.h b/linden/indra/llui/lltabcontainer.h index 3056c0a..c77547a 100644 --- a/linden/indra/llui/lltabcontainer.h +++ b/linden/indra/llui/lltabcontainer.h @@ -2,6 +2,8 @@ * @file lltabcontainer.h * @brief LLTabContainerCommon base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Fear my script-fu! diff --git a/linden/indra/llui/lltabcontainervertical.cpp b/linden/indra/llui/lltabcontainervertical.cpp index e2d84a5..adbca47 100644 --- a/linden/indra/llui/lltabcontainervertical.cpp +++ b/linden/indra/llui/lltabcontainervertical.cpp @@ -2,6 +2,8 @@ * @file lltabcontainervertical.cpp * @brief LLTabContainerVertical base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Fear my script-fu! diff --git a/linden/indra/llui/lltabcontainervertical.h b/linden/indra/llui/lltabcontainervertical.h index 77817c2..a5d3c53 100644 --- a/linden/indra/llui/lltabcontainervertical.h +++ b/linden/indra/llui/lltabcontainervertical.h @@ -2,6 +2,8 @@ * @file lltabcontainervertical.h * @brief LLTabContainerVertical base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Fear my script-fu! diff --git a/linden/indra/llui/lltextbox.cpp b/linden/indra/llui/lltextbox.cpp index ba0747f..c0b0788 100644 --- a/linden/indra/llui/lltextbox.cpp +++ b/linden/indra/llui/lltextbox.cpp @@ -2,6 +2,8 @@ * @file lltextbox.cpp * @brief A text display widget * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -158,7 +161,7 @@ BOOL LLTextBox::handleMouseUp(S32 x, S32 y, MASK mask) return handled; } -void LLTextBox::setText(const LLString& text) +void LLTextBox::setText(const LLStringExplicit& text) { mText.assign(text); setLineLengths(); @@ -191,7 +194,7 @@ void LLTextBox::setLineLengths() } } -void LLTextBox::setWrappedText(const LLString& in_text, F32 max_width) +void LLTextBox::setWrappedText(const LLStringExplicit& in_text, F32 max_width) { if (max_width < 0.0) { @@ -283,7 +286,7 @@ LLSD LLTextBox::getValue() const return LLSD(getText()); } -BOOL LLTextBox::setTextArg( const LLString& key, const LLString& text ) +BOOL LLTextBox::setTextArg( const LLString& key, const LLStringExplicit& text ) { mText.setArg(key, text); setLineLengths(); diff --git a/linden/indra/llui/lltextbox.h b/linden/indra/llui/lltextbox.h index e8d4690..7e7018a 100644 --- a/linden/indra/llui/lltextbox.h +++ b/linden/indra/llui/lltextbox.h @@ -2,6 +2,8 @@ * @file lltextbox.h * @brief A single text item display * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTEXTBOX_H @@ -68,8 +71,8 @@ public: void setDisabledColor( const LLColor4& c) { mDisabledColor = c; } void setBackgroundColor( const LLColor4& c) { mBackgroundColor = c; } void setBorderColor( const LLColor4& c) { mBorderColor = c; } - void setText( const LLString& text ); - void setWrappedText(const LLString& text, F32 max_width = -1.0); + void setText( const LLStringExplicit& text ); + void setWrappedText(const LLStringExplicit& text, F32 max_width = -1.0); // default width means use existing control width void setBackgroundVisible(BOOL visible) { mBackgroundVisible = visible; } @@ -94,7 +97,7 @@ public: virtual void setValue(const LLSD& value ); virtual LLSD getValue() const; - virtual BOOL setTextArg( const LLString& key, const LLString& text ); + virtual BOOL setTextArg( const LLString& key, const LLStringExplicit& text ); protected: void setLineLengths(); diff --git a/linden/indra/llui/lltexteditor.cpp b/linden/indra/llui/lltexteditor.cpp index 552a9c9..12ad339 100644 --- a/linden/indra/llui/lltexteditor.cpp +++ b/linden/indra/llui/lltexteditor.cpp @@ -2,6 +2,8 @@ * @file lltexteditor.cpp * @brief LLTextEditor base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Text editor widget to let users enter a a multi-line ASCII document. @@ -78,7 +81,8 @@ const S32 SPACES_PER_TAB = 4; LLColor4 LLTextEditor::mLinkColor = LLColor4::blue; void (* LLTextEditor::mURLcallback)(const char*) = NULL; -BOOL (* LLTextEditor::mSecondlifeURLcallback)(LLString) = NULL; +bool (* LLTextEditor::mSecondlifeURLcallback)(const std::string&) = NULL; +bool (* LLTextEditor::mSecondlifeURLcallbackRightClick)(const std::string&) = NULL; /////////////////////////////////////////////////////////////////// //virtuals @@ -306,7 +310,8 @@ LLTextEditor::LLTextEditor( mMouseDownX(0), mMouseDownY(0), mLastSelectionX(-1), - mLastSelectionY(-1) + mLastSelectionY(-1), + mLastIMEPosition(-1,-1) { mSourceID.generate(); @@ -515,7 +520,7 @@ void LLTextEditor::truncate() } } -void LLTextEditor::setText(const LLString &utf8str) +void LLTextEditor::setText(const LLStringExplicit &utf8str) { // LLString::removeCRLF(utf8str); mUTF8Text = utf8str_removeCRLF(utf8str); @@ -2819,7 +2824,15 @@ void LLTextEditor::drawCursor() 1); } - + // Make sure the IME is in the right place + LLRect screen_pos = getScreenRect(); + LLCoordGL ime_pos( screen_pos.mLeft + llfloor(cursor_left), screen_pos.mBottom + llfloor(cursor_top) ); + if ( ime_pos.mX != mLastIMEPosition.mX || ime_pos.mY != mLastIMEPosition.mY ) + { + mLastIMEPosition.mX = ime_pos.mX; + mLastIMEPosition.mY = ime_pos.mY; + getWindow()->setLanguageTextInput( ime_pos ); + } } } } @@ -3055,7 +3068,7 @@ void LLTextEditor::onTabInto() void LLTextEditor::clear() { - setText(""); + setText(LLString::null); } // Start or stop the editor from accepting text-editing keystrokes @@ -3936,7 +3949,7 @@ BOOL LLTextEditor::importBuffer(const LLString& buffer ) if( success ) { // Actually set the text - setText( text ); + setText( LLStringExplicit(text) ); } delete[] text; diff --git a/linden/indra/llui/lltexteditor.h b/linden/indra/llui/lltexteditor.h index 4bcfcfc..55aba57 100644 --- a/linden/indra/llui/lltexteditor.h +++ b/linden/indra/llui/lltexteditor.h @@ -2,6 +2,8 @@ * @file lltexteditor.h * @brief LLTextEditor base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Text editor widget to let users enter a a multi-line ASCII document// @@ -214,9 +217,10 @@ public: // Callbacks static void setLinkColor(LLColor4 color) { mLinkColor = color; } - static void setURLCallbacks( void (*callback1) (const char* url), - BOOL (*callback2) (LLString url) ) - { mURLcallback = callback1; mSecondlifeURLcallback = callback2;} + static void setURLCallbacks(void (*callback1) (const char* url), + bool (*callback2) (const std::string& url), + bool (*callback3) (const std::string& url) ) + { mURLcallback = callback1; mSecondlifeURLcallback = callback2; mSecondlifeURLcallbackRightClick = callback3;} void setOnScrollEndCallback(void (*callback)(void*), void* userdata); @@ -227,7 +231,7 @@ public: const LLString& getText() const; // Non-undoable - void setText(const LLString &utf8str); + void setText(const LLStringExplicit &utf8str); void setWText(const LLWString &wtext); S32 getMaxLength() const { return mMaxTextLength; } @@ -338,7 +342,8 @@ public: LLKeywords mKeywords; static LLColor4 mLinkColor; static void (*mURLcallback) (const char* url); - static BOOL (*mSecondlifeURLcallback) (LLString url); + static bool (*mSecondlifeURLcallback) (const std::string& url); + static bool (*mSecondlifeURLcallbackRightClick) (const std::string& url); protected: LLWString mWText; mutable LLString mUTF8Text; @@ -434,6 +439,8 @@ protected: BOOL mParseHTML; LLString mHTML; + + LLCoordGL mLastIMEPosition; // Last position of the IME editor }; class LLTextSegment diff --git a/linden/indra/llui/llui.cpp b/linden/indra/llui/llui.cpp index d0815a7..1d2d8a7 100644 --- a/linden/indra/llui/llui.cpp +++ b/linden/indra/llui/llui.cpp @@ -2,6 +2,8 @@ * @file llui.cpp * @brief UI implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Utilities functions the user interface needs diff --git a/linden/indra/llui/llui.h b/linden/indra/llui/llui.h index 201d88f..4d831ca 100644 --- a/linden/indra/llui/llui.h +++ b/linden/indra/llui/llui.h @@ -2,6 +2,8 @@ * @file llui.h * @brief UI implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // All immediate-mode gl drawing should happen here. diff --git a/linden/indra/llui/lluiconstants.h b/linden/indra/llui/lluiconstants.h index a51267a..9e50696 100644 --- a/linden/indra/llui/lluiconstants.h +++ b/linden/indra/llui/lluiconstants.h @@ -2,6 +2,8 @@ * @file lluiconstants.h * @brief Compile-time configuration for UI * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLUICONSTANTS_H diff --git a/linden/indra/llui/lluictrl.cpp b/linden/indra/llui/lluictrl.cpp index 0ac3916..7d35475 100644 --- a/linden/indra/llui/lluictrl.cpp +++ b/linden/indra/llui/lluictrl.cpp @@ -3,6 +3,8 @@ * @author James Cook, Richard Nelson, Tom Yedwab * @brief Abstract base class for UI controls * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //#include "llviewerprecompiledheaders.h" @@ -96,13 +99,13 @@ void LLUICtrl::onCommit() } // virtual -BOOL LLUICtrl::setTextArg( const LLString& key, const LLString& text ) +BOOL LLUICtrl::setTextArg( const LLString& key, const LLStringExplicit& text ) { return FALSE; } // virtual -BOOL LLUICtrl::setLabelArg( const LLString& key, const LLString& text ) +BOOL LLUICtrl::setLabelArg( const LLString& key, const LLStringExplicit& text ) { return FALSE; } diff --git a/linden/indra/llui/lluictrl.h b/linden/indra/llui/lluictrl.h index 455a8c0..00f7874 100644 --- a/linden/indra/llui/lluictrl.h +++ b/linden/indra/llui/lluictrl.h @@ -3,6 +3,8 @@ * @author James Cook, Richard Nelson, Tom Yedwab * @brief Abstract base class for UI controls * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLUICTRL_H @@ -69,10 +72,10 @@ public: virtual LLSD getValue() const { return LLSD(); } // Defaults to no-op - virtual BOOL setTextArg( const LLString& key, const LLString& text ); + virtual BOOL setTextArg( const LLString& key, const LLStringExplicit& text ); // Defaults to no-op - virtual BOOL setLabelArg( const LLString& key, const LLString& text ); + virtual BOOL setLabelArg( const LLString& key, const LLStringExplicit& text ); // Defaults to return NULL virtual LLCtrlSelectionInterface* getSelectionInterface(); diff --git a/linden/indra/llui/lluictrlfactory.cpp b/linden/indra/llui/lluictrlfactory.cpp index 70f1e3e..4b4c463 100644 --- a/linden/indra/llui/lluictrlfactory.cpp +++ b/linden/indra/llui/lluictrlfactory.cpp @@ -2,6 +2,8 @@ * @file lluictrlfactory.cpp * @brief Factory class for creating UI controls * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -470,7 +473,7 @@ LLPieMenu *LLUICtrlFactory::buildPieMenu(const LLString &filename, LLView* paren // root must be called panel if( !root->hasName( LL_PIE_MENU_TAG )) { - llwarns << "Root node should be named " LL_PIE_MENU_TAG " in : " << filename << llendl; + llwarns << "Root node should be named " << LL_PIE_MENU_TAG << " in : " << filename << llendl; return NULL; } @@ -805,3 +808,4 @@ void LLUICtrlFactory::registerCreator(LLString ctrlname, creator_function_t func mCreatorFunctions[ctrlname] = function; } + diff --git a/linden/indra/llui/lluictrlfactory.h b/linden/indra/llui/lluictrlfactory.h index e12017d..486ed12 100644 --- a/linden/indra/llui/lluictrlfactory.h +++ b/linden/indra/llui/lluictrlfactory.h @@ -2,6 +2,8 @@ * @file lluictrlfactory.h * @brief Factory class for creating UI controls * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLUICTRLFACTORY_H diff --git a/linden/indra/llui/lluistring.cpp b/linden/indra/llui/lluistring.cpp index cf1b0e0..b0da5dd 100644 --- a/linden/indra/llui/lluistring.cpp +++ b/linden/indra/llui/lluistring.cpp @@ -2,6 +2,8 @@ * @file lluistring.cpp * @brief LLUIString base class * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llui/lluistring.h b/linden/indra/llui/lluistring.h index c5d9152..ede8aef 100644 --- a/linden/indra/llui/lluistring.h +++ b/linden/indra/llui/lluistring.h @@ -3,6 +3,8 @@ * @author: Steve Bennetts * @brief LLUIString base class * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLUISTRING_H diff --git a/linden/indra/llui/lluixmltags.h b/linden/indra/llui/lluixmltags.h index 7728d73..305223d 100644 --- a/linden/indra/llui/lluixmltags.h +++ b/linden/indra/llui/lluixmltags.h @@ -1,6 +1,8 @@ /** * @file lluixmltags.h * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,98 +25,99 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_UI_XML_TAGS_H #define LL_UI_XML_TAGS_H -#define LL_BUTTON_TAG "button" -#define LL_UI_CTRL_LOCATE_TAG "locate" -#define LL_PAD_TAG "pad" -#define LL_CHECK_BOX_CTRL_TAG "check_box" -#define LL_COMBO_BOX_TAG "combo_box" -#define LL_DRAG_HANDLE_TOP_TAG "drag_handle_top" -#define LL_DRAG_HANDLE_LEFT_TAG "drag_handle_left" -#define LL_FLOATER_TAG "floater" -#define LL_FLOATER_VIEW_TAG "floater_view" -#define LL_MULTI_FLOATER_TAG "multi_floater" -#define LL_ICON_CTRL_TAG "icon" -#define LL_LINE_EDITOR_TAG "line_editor" -#define LL_SEARCH_EDITOR_TAG "search_editor" -#define LL_MENU_ITEM_TAG "menu_item" -#define LL_MENU_GL_TAG "menu" -#define LL_MENU_BAR_GL_TAG "menu_bar" -#define LL_MENU_HOLDER_GL_TAG "menu_holder" -#define LL_PANEL_TAG "panel" -#define LL_RADIO_GROUP_TAG "radio_group" -#define LL_RESIZE_BAR_TAG "resize_bar" -#define LL_RESIZE_HANDLE_TAG "resize_handle" -#define LL_SCROLLBAR_TAG "scrollbar" -#define LL_SCROLLABLE_CONTAINER_VIEW_TAG "scroll_container" -#define LL_SCROLL_LIST_CTRL_TAG "scroll_list" -#define LL_SLIDER_CTRL_TAG "slider" -#define LL_SLIDER_TAG "slider_bar" -#define LL_SPIN_CTRL_TAG "spinner" -#define LL_TAB_CONTAINER_COMMON_TAG "tab_container" -#define LL_TEXT_BOX_TAG "text" -#define LL_TEXT_EDITOR_TAG "text_editor" -#define LL_VIEW_BORDER_TAG "view_border" -#define LL_COLOR_SWATCH_TAG "color_swatch" -#define LL_INVENTORY_PANEL_TAG "inventory_panel" -#define LL_NAME_EDITOR_TAG "name_editor" -#define LL_NAME_LIST_TAG "name_list" -#define LL_TEXTURE_PICKER_TAG "texture_picker" -#define LL_VOLUME_SLIDER_CTRL_TAG "volume_slider" -#define LL_WEB_BROWSER_CTRL_TAG "web_browser" -#define LL_STAT_VIEW_TAG "stat_view" -#define LL_INVENTORY_PANEL_TAG "inventory_panel" -#define LL_PROGRESS_VIEW_TAG "progress_view" -#define LL_STAT_BAR_TAG "stat_bar" -#define LL_STATUS_BAR_TAG "status_bar" -#define LL_VIEWER_TEXT_EDITOR_TAG "viewer_text_editor" -#define LL_TALK_VIEW_TAG "talk_view" -#define LL_COLOR_SWATCH_CTRL_TAG "color_swatch" -#define LL_GL_TEX_MEM_BAR_TAG "tex_mem_bar" -#define LL_TEXTURE_CTRL_TAG "texture_picker" -#define LL_TEXTURE_VIEW_TAG "texture_view" -#define LL_NAME_LIST_CTRL_TAG "name_list" -#define LL_STAT_GRAPH_TAG "stat_graph" -#define LL_NAME_EDITOR_TAG "name_editor" -#define LL_DROP_TARGET_TAG "drop_target" -#define LL_OVERLAY_BAR_TAG "overlay_bar" -#define LL_NET_MAP_TAG "net_map" -#define LL_HUD_VIEW_TAG "hud_view" -#define LL_MEMORY_VIEW_TAG "memory_view" -#define LL_MEDIA_REMOTE_CTRL_TAG "media_remote" -#define LL_MORPH_VIEW_TAG "morph_view" -#define LL_FRAME_STAT_VIEW_TAG "frame_stat_view" -#define LL_FOLDER_VIEW_TAG "folder_view"; -#define LL_SNAPSHOT_LIVE_PREVIEW_TAG "snapshot_preview" -#define LL_HOVER_VIEW_TAG "hover_view" -#define LL_VELOCITY_BAR_TAG "velocity_bar" -#define LL_PERMISSIONS_VIEW_TAG "permissions_view" -#define LL_SCROLLING_PANEL_LIST_TAG "scrolling_panel_list" -#define LL_CONTAINER_VIEW_TAG "container_view" -#define LL_CONSOLE_TAG "console" -#define LL_DEBUG_VIEW_TAG "debug_view" -#define LL_AUDIOSTATUS_TAG "audio_status" -#define LL_FAST_TIMER_VIEW_TAG "fast_timer_view" -#define LL_MENU_ITEM_TEAR_OFF_GL_TAG "tearoff_menu" -#define LL_MENU_ITEM_BLANK_GL_TAG "menu_item_blank" -#define LL_MENU_ITEM_CALL_GL_TAG "menu_item_call" -#define LL_MENU_ITEM_CHECK_GL_TAG "menu_item_check" -#define LL_MENU_ITEM_BRANCH_GL_TAG "menu_item_branch" -#define LL_MENU_ITEM_BRANCH_DOWN_GL_TAG "menu_item_branch_down" -#define LL_PIE_MENU_BRANCH_TAG "pie_menu_branch" -#define LL_PIE_MENU_TAG "pie_menu" -#define LL_MENU_ITEM_SEPARATOR_GL_TAG "menu_item_separator" -#define LL_MENU_ITEM_VERTICAL_SEPARATOR_GL_TAG "menu_item_vertical_separator" -#define LL_ROOT_VIEW_TAG "root_view" -#define LL_FOLDER_VIEW_ITEM_TAG "folder_item" -#define LL_FOLDER_VIEW_FOLDER_TAG "folder" -#define LL_TEXTURE_BAR_TAG "texture_bar" +#define LL_BUTTON_TAG LLString("button") +#define LL_UI_CTRL_LOCATE_TAG LLString("locate") +#define LL_PAD_TAG LLString("pad") +#define LL_CHECK_BOX_CTRL_TAG LLString("check_box") +#define LL_COMBO_BOX_TAG LLString("combo_box") +#define LL_DRAG_HANDLE_TOP_TAG LLString("drag_handle_top") +#define LL_DRAG_HANDLE_LEFT_TAG LLString("drag_handle_left") +#define LL_FLOATER_TAG LLString("floater") +#define LL_FLOATER_VIEW_TAG LLString("floater_view") +#define LL_MULTI_FLOATER_TAG LLString("multi_floater") +#define LL_ICON_CTRL_TAG LLString("icon") +#define LL_LINE_EDITOR_TAG LLString("line_editor") +#define LL_SEARCH_EDITOR_TAG LLString("search_editor") +#define LL_MENU_ITEM_TAG LLString("menu_item") +#define LL_MENU_GL_TAG LLString("menu") +#define LL_MENU_BAR_GL_TAG LLString("menu_bar") +#define LL_MENU_HOLDER_GL_TAG LLString("menu_holder") +#define LL_PANEL_TAG LLString("panel") +#define LL_RADIO_GROUP_TAG LLString("radio_group") +#define LL_RESIZE_BAR_TAG LLString("resize_bar") +#define LL_RESIZE_HANDLE_TAG LLString("resize_handle") +#define LL_SCROLLBAR_TAG LLString("scrollbar") +#define LL_SCROLLABLE_CONTAINER_VIEW_TAG LLString("scroll_container") +#define LL_SCROLL_LIST_CTRL_TAG LLString("scroll_list") +#define LL_SLIDER_CTRL_TAG LLString("slider") +#define LL_SLIDER_TAG LLString("slider_bar") +#define LL_SPIN_CTRL_TAG LLString("spinner") +#define LL_TAB_CONTAINER_COMMON_TAG LLString("tab_container") +#define LL_TEXT_BOX_TAG LLString("text") +#define LL_TEXT_EDITOR_TAG LLString("text_editor") +#define LL_VIEW_BORDER_TAG LLString("view_border") +#define LL_COLOR_SWATCH_TAG LLString("color_swatch") +#define LL_INVENTORY_PANEL_TAG LLString("inventory_panel") +#define LL_NAME_EDITOR_TAG LLString("name_editor") +#define LL_NAME_LIST_TAG LLString("name_list") +#define LL_TEXTURE_PICKER_TAG LLString("texture_picker") +#define LL_VOLUME_SLIDER_CTRL_TAG LLString("volume_slider") +#define LL_WEB_BROWSER_CTRL_TAG LLString("web_browser") +#define LL_STAT_VIEW_TAG LLString("stat_view") +#define LL_INVENTORY_PANEL_TAG LLString("inventory_panel") +#define LL_PROGRESS_VIEW_TAG LLString("progress_view") +#define LL_STAT_BAR_TAG LLString("stat_bar") +#define LL_STATUS_BAR_TAG LLString("status_bar") +#define LL_VIEWER_TEXT_EDITOR_TAG LLString("viewer_text_editor") +#define LL_TALK_VIEW_TAG LLString("talk_view") +#define LL_COLOR_SWATCH_CTRL_TAG LLString("color_swatch") +#define LL_GL_TEX_MEM_BAR_TAG LLString("tex_mem_bar") +#define LL_TEXTURE_CTRL_TAG LLString("texture_picker") +#define LL_TEXTURE_VIEW_TAG LLString("texture_view") +#define LL_NAME_LIST_CTRL_TAG LLString("name_list") +#define LL_STAT_GRAPH_TAG LLString("stat_graph") +#define LL_NAME_EDITOR_TAG LLString("name_editor") +#define LL_DROP_TARGET_TAG LLString("drop_target") +#define LL_OVERLAY_BAR_TAG LLString("overlay_bar") +#define LL_NET_MAP_TAG LLString("net_map") +#define LL_HUD_VIEW_TAG LLString("hud_view") +#define LL_MEMORY_VIEW_TAG LLString("memory_view") +#define LL_MEDIA_REMOTE_CTRL_TAG LLString("media_remote") +#define LL_MORPH_VIEW_TAG LLString("morph_view") +#define LL_FRAME_STAT_VIEW_TAG LLString("frame_stat_view") +#define LL_FOLDER_VIEW_TAG LLString("folder_view") +#define LL_SNAPSHOT_LIVE_PREVIEW_TAG LLString("snapshot_preview") +#define LL_HOVER_VIEW_TAG LLString("hover_view") +#define LL_VELOCITY_BAR_TAG LLString("velocity_bar") +#define LL_PERMISSIONS_VIEW_TAG LLString("permissions_view") +#define LL_SCROLLING_PANEL_LIST_TAG LLString("scrolling_panel_list") +#define LL_CONTAINER_VIEW_TAG LLString("container_view") +#define LL_CONSOLE_TAG LLString("console") +#define LL_DEBUG_VIEW_TAG LLString("debug_view") +#define LL_AUDIOSTATUS_TAG LLString("audio_status") +#define LL_FAST_TIMER_VIEW_TAG LLString("fast_timer_view") +#define LL_MENU_ITEM_TEAR_OFF_GL_TAG LLString("tearoff_menu") +#define LL_MENU_ITEM_BLANK_GL_TAG LLString("menu_item_blank") +#define LL_MENU_ITEM_CALL_GL_TAG LLString("menu_item_call") +#define LL_MENU_ITEM_CHECK_GL_TAG LLString("menu_item_check") +#define LL_MENU_ITEM_BRANCH_GL_TAG LLString("menu_item_branch") +#define LL_MENU_ITEM_BRANCH_DOWN_GL_TAG LLString("menu_item_branch_down") +#define LL_PIE_MENU_BRANCH_TAG LLString("pie_menu_branch") +#define LL_PIE_MENU_TAG LLString("pie_menu") +#define LL_MENU_ITEM_SEPARATOR_GL_TAG LLString("menu_item_separator") +#define LL_MENU_ITEM_VERTICAL_SEPARATOR_GL_TAG LLString("menu_item_vertical_separator") +#define LL_ROOT_VIEW_TAG LLString("root_view") +#define LL_FOLDER_VIEW_ITEM_TAG LLString("folder_item") +#define LL_FOLDER_VIEW_FOLDER_TAG LLString("folder") +#define LL_TEXTURE_BAR_TAG LLString("texture_bar") #define LL_JOYSTICK_SLIDE "joystick_slide" #define LL_JOYSTICK_TURN "joystick_turn" -#define LL_GROUP_DROP_TARGET_TAG "group_drop_target" -#define LL_LAYOUT_STACK_TAG "layout_stack" +#define LL_GROUP_DROP_TARGET_TAG LLString("group_drop_target") +#define LL_LAYOUT_STACK_TAG LLString("layout_stack") #endif diff --git a/linden/indra/llui/llundo.cpp b/linden/indra/llui/llundo.cpp index 4e62bad..6fd5d08 100644 --- a/linden/indra/llui/llundo.cpp +++ b/linden/indra/llui/llundo.cpp @@ -2,6 +2,8 @@ * @file llundo.cpp * @brief LLUndo class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Generic interface for undo/redo circular buffer diff --git a/linden/indra/llui/llundo.h b/linden/indra/llui/llundo.h index 9a4bece..8b98297 100644 --- a/linden/indra/llui/llundo.h +++ b/linden/indra/llui/llundo.h @@ -2,6 +2,8 @@ * @file llundo.h * @brief LLUndo class header file * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLUNDO_H diff --git a/linden/indra/llui/llview.cpp b/linden/indra/llui/llview.cpp index 2a62602..ef91d9c 100644 --- a/linden/indra/llui/llview.cpp +++ b/linden/indra/llui/llview.cpp @@ -3,6 +3,8 @@ * @author James Cook * @brief Container for other views, anything that draws. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,29 +27,28 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" #include "llview.h" -#include "llstring.h" -#include "llrect.h" -#include "llgl.h" +#include +#include + #include "llevent.h" #include "llfontgl.h" #include "llfocusmgr.h" +#include "llgl.h" #include "llglheaders.h" -#include "llwindow.h" +#include "llrect.h" #include "llstl.h" -#include "lluictrl.h" #include "llui.h" // colors saved settings +#include "lluictrl.h" +#include "llwindow.h" #include "v3color.h" -#include "llstl.h" -#include - -#include BOOL LLView::sDebugRects = FALSE; BOOL LLView::sDebugKeys = FALSE; @@ -785,7 +786,7 @@ void LLView::setHidden(BOOL hidden) } // virtual -BOOL LLView::setLabelArg(const LLString& key, const LLString& text) +BOOL LLView::setLabelArg(const LLString& key, const LLStringExplicit& text) { return FALSE; } @@ -1711,7 +1712,8 @@ BOOL LLView::hasChild(const LLString& childname, BOOL recurse) const //----------------------------------------------------------------------------- LLView* LLView::getChildByName(const LLString& name, BOOL recurse) const { - if(name.empty()) return NULL; + if(name.empty()) + return NULL; child_list_const_iter_t child_it; // Look for direct children *first* for ( child_it = mChildList.begin(); child_it != mChildList.end(); ++child_it) @@ -1724,7 +1726,7 @@ LLView* LLView::getChildByName(const LLString& name, BOOL recurse) const } if (recurse) { - // Look inside the child as well. + // Look inside each child as well. for ( child_it = mChildList.begin(); child_it != mChildList.end(); ++child_it) { LLView* childp = *child_it; diff --git a/linden/indra/llui/llview.h b/linden/indra/llui/llview.h index 053ef82..63c1efc 100644 --- a/linden/indra/llui/llview.h +++ b/linden/indra/llui/llview.h @@ -2,6 +2,8 @@ * @file llview.h * @brief Container for other views, anything that draws. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEW_H @@ -33,23 +36,19 @@ // the HUD or a dialog box or a button. It can also contain sub-views // and child widgets -#include -#include - -#include "lluixmltags.h" -#include "llrect.h" +#include "llcoord.h" +#include "llfontgl.h" +#include "llmortician.h" #include "llmousehandler.h" -#include "stdenums.h" +#include "llnametable.h" #include "llsd.h" #include "llstring.h" -#include "llnametable.h" -#include "llcoord.h" -#include "llmortician.h" -#include "llxmlnode.h" -#include "llfontgl.h" -#include "llviewquery.h" - +#include "llrect.h" #include "llui.h" +#include "lluixmltags.h" +#include "llviewquery.h" +#include "llxmlnode.h" +#include "stdenums.h" class LLColor4; class LLWindow; @@ -291,7 +290,7 @@ public: virtual void setHidden(BOOL hidden); // Never show (replacement text) // by default, does nothing and returns false - virtual BOOL setLabelArg( const LLString& key, const LLString& text ); + virtual BOOL setLabelArg( const LLString& key, const LLStringExplicit& text ); virtual void onVisibilityChange ( BOOL curVisibilityIn ); diff --git a/linden/indra/llui/llviewborder.cpp b/linden/indra/llui/llviewborder.cpp index 84f396b..f6cbe3a 100644 --- a/linden/indra/llui/llviewborder.cpp +++ b/linden/indra/llui/llviewborder.cpp @@ -2,6 +2,8 @@ * @file llviewborder.cpp * @brief LLViewBorder base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // A customizable decorative border. Does not interact with mouse events. diff --git a/linden/indra/llui/llviewborder.h b/linden/indra/llui/llviewborder.h index 38d6c9f..6a91c5e 100644 --- a/linden/indra/llui/llviewborder.h +++ b/linden/indra/llui/llviewborder.h @@ -2,6 +2,8 @@ * @file llviewborder.h * @brief LLViewBorder base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // A customizable decorative border. Does not interact with mouse events. diff --git a/linden/indra/llui/llviewquery.cpp b/linden/indra/llui/llviewquery.cpp index 314a483..c07587f 100644 --- a/linden/indra/llui/llviewquery.cpp +++ b/linden/indra/llui/llviewquery.cpp @@ -2,6 +2,8 @@ * @file llviewquery.cpp * @brief Implementation of view query class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llui/llviewquery.h b/linden/indra/llui/llviewquery.h index a35726a..3919ba4 100644 --- a/linden/indra/llui/llviewquery.h +++ b/linden/indra/llui/llviewquery.h @@ -2,6 +2,8 @@ * @file llviewquery.h * @brief Query algorithm for flattening and filtering the view hierarchy. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWQUERY_H diff --git a/linden/indra/llvfs/lldir.cpp b/linden/indra/llvfs/lldir.cpp index 5f0efbe..a20b21f 100644 --- a/linden/indra/llvfs/lldir.cpp +++ b/linden/indra/llvfs/lldir.cpp @@ -2,6 +2,8 @@ * @file lldir.cpp * @brief implementation of directory utilities base class * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -31,6 +34,7 @@ #if !LL_WINDOWS #include #include +#include #else #include #endif diff --git a/linden/indra/llvfs/lldir.h b/linden/indra/llvfs/lldir.h index 86d4e15..b133b7d 100644 --- a/linden/indra/llvfs/lldir.h +++ b/linden/indra/llvfs/lldir.h @@ -2,6 +2,8 @@ * @file lldir.h * @brief Definition of directory utilities class * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDIR_H diff --git a/linden/indra/llvfs/lldir_linux.cpp b/linden/indra/llvfs/lldir_linux.cpp index 7cf1c2a..8f9f577 100644 --- a/linden/indra/llvfs/lldir_linux.cpp +++ b/linden/indra/llvfs/lldir_linux.cpp @@ -2,6 +2,8 @@ * @file lldir_linux.cpp * @brief Implementation of directory utilities for linux * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llvfs/lldir_linux.h b/linden/indra/llvfs/lldir_linux.h index dd56239..a81df89 100644 --- a/linden/indra/llvfs/lldir_linux.h +++ b/linden/indra/llvfs/lldir_linux.h @@ -2,6 +2,8 @@ * @file lldir_linux.h * @brief Definition of directory utilities class for linux * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDIR_LINUX_H @@ -31,7 +34,6 @@ #include "lldir.h" -#include #include #include diff --git a/linden/indra/llvfs/lldir_mac.cpp b/linden/indra/llvfs/lldir_mac.cpp index db6e20d..3cf70d7 100644 --- a/linden/indra/llvfs/lldir_mac.cpp +++ b/linden/indra/llvfs/lldir_mac.cpp @@ -2,6 +2,8 @@ * @file lldir_mac.cpp * @brief Implementation of directory utilities for Mac OS X * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #if LL_DARWIN diff --git a/linden/indra/llvfs/lldir_mac.h b/linden/indra/llvfs/lldir_mac.h index 925691e..c1244a2 100644 --- a/linden/indra/llvfs/lldir_mac.h +++ b/linden/indra/llvfs/lldir_mac.h @@ -2,6 +2,8 @@ * @file lldir_mac.h * @brief Definition of directory utilities class for Mac OS X * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDIR_MAC_H @@ -31,7 +34,6 @@ #include "lldir.h" -#include #include class LLDir_Mac : public LLDir diff --git a/linden/indra/llvfs/lldir_solaris.cpp b/linden/indra/llvfs/lldir_solaris.cpp index 41262aa..b13d3d0 100644 --- a/linden/indra/llvfs/lldir_solaris.cpp +++ b/linden/indra/llvfs/lldir_solaris.cpp @@ -2,6 +2,8 @@ * @file fmodwrapper.cpp * @brief dummy source file for building a shared library to wrap libfmod.a * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llvfs/lldir_solaris.h b/linden/indra/llvfs/lldir_solaris.h index 4a8feed..34e7f71 100644 --- a/linden/indra/llvfs/lldir_solaris.h +++ b/linden/indra/llvfs/lldir_solaris.h @@ -2,6 +2,8 @@ * @file fmodwrapper.cpp * @brief dummy source file for building a shared library to wrap libfmod.a * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDIR_SOLARIS_H @@ -31,7 +34,6 @@ #include "lldir.h" -#include #include #include diff --git a/linden/indra/llvfs/lldir_win32.cpp b/linden/indra/llvfs/lldir_win32.cpp index 9411c71..277cfea 100644 --- a/linden/indra/llvfs/lldir_win32.cpp +++ b/linden/indra/llvfs/lldir_win32.cpp @@ -2,6 +2,8 @@ * @file lldir_win32.cpp * @brief Implementation of directory utilities for windows * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #if LL_WINDOWS diff --git a/linden/indra/llvfs/lldir_win32.h b/linden/indra/llvfs/lldir_win32.h index 0eacc5e..bddf175 100644 --- a/linden/indra/llvfs/lldir_win32.h +++ b/linden/indra/llvfs/lldir_win32.h @@ -2,6 +2,8 @@ * @file lldir_win32.h * @brief Definition of directory utilities class for windows * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDIR_WIN32_H diff --git a/linden/indra/llvfs/lllfsthread.cpp b/linden/indra/llvfs/lllfsthread.cpp index fdfb0ce..8d2dc72 100644 --- a/linden/indra/llvfs/lllfsthread.cpp +++ b/linden/indra/llvfs/lllfsthread.cpp @@ -2,6 +2,8 @@ * @file lllfsthread.cpp * @brief LLLFSThread base class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llvfs/lllfsthread.h b/linden/indra/llvfs/lllfsthread.h index 25b4c6b..2a23f55 100644 --- a/linden/indra/llvfs/lllfsthread.h +++ b/linden/indra/llvfs/lllfsthread.h @@ -2,6 +2,8 @@ * @file lllfsthread.h * @brief LLLFSThread base class * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLLFSTHREAD_H diff --git a/linden/indra/llvfs/llvfile.cpp b/linden/indra/llvfs/llvfile.cpp index f3db189..b25ec4a 100644 --- a/linden/indra/llvfs/llvfile.cpp +++ b/linden/indra/llvfs/llvfile.cpp @@ -2,6 +2,8 @@ * @file llvfile.cpp * @brief Implementation of virtual file * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llvfs/llvfile.h b/linden/indra/llvfs/llvfile.h index 0c4950b..3d81483 100644 --- a/linden/indra/llvfs/llvfile.h +++ b/linden/indra/llvfs/llvfile.h @@ -2,6 +2,8 @@ * @file llvfile.h * @brief Definition of virtual file * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVFILE_H diff --git a/linden/indra/llvfs/llvfs.cpp b/linden/indra/llvfs/llvfs.cpp index 89db67b..417e48c 100644 --- a/linden/indra/llvfs/llvfs.cpp +++ b/linden/indra/llvfs/llvfs.cpp @@ -2,6 +2,8 @@ * @file llvfs.cpp * @brief Implementation of virtual file system * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,13 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" -#include #include -#include #include #include #if LL_WINDOWS diff --git a/linden/indra/llvfs/llvfs.h b/linden/indra/llvfs/llvfs.h index 2c1b8de..a068c0d 100644 --- a/linden/indra/llvfs/llvfs.h +++ b/linden/indra/llvfs/llvfs.h @@ -2,6 +2,8 @@ * @file llvfs.h * @brief Definition of virtual file system * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,13 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVFS_H #define LL_LLVFS_H -#include -#include #include #include "lluuid.h" #include "linked_lists.h" diff --git a/linden/indra/llvfs/llvfsthread.cpp b/linden/indra/llvfs/llvfsthread.cpp index d93b312..fbfbdff 100644 --- a/linden/indra/llvfs/llvfsthread.cpp +++ b/linden/indra/llvfs/llvfsthread.cpp @@ -2,6 +2,8 @@ * @file llvfsthread.cpp * @brief LLVFSThread implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llvfs/llvfsthread.h b/linden/indra/llvfs/llvfsthread.h index 76ce5ee..6028199 100644 --- a/linden/indra/llvfs/llvfsthread.h +++ b/linden/indra/llvfs/llvfsthread.h @@ -2,6 +2,8 @@ * @file llvfsthread.h * @brief LLVFSThread definition * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVFSTHREAD_H diff --git a/linden/indra/llwindow/lldxhardware.cpp b/linden/indra/llwindow/lldxhardware.cpp index 82d80ec..1a39e68 100644 --- a/linden/indra/llwindow/lldxhardware.cpp +++ b/linden/indra/llwindow/lldxhardware.cpp @@ -2,6 +2,8 @@ * @file lldxhardware.cpp * @brief LLDXHardware implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifdef LL_WINDOWS @@ -32,7 +35,6 @@ #include "linden_common.h" -#include #include #include diff --git a/linden/indra/llwindow/lldxhardware.h b/linden/indra/llwindow/lldxhardware.h index 0574880..1d5d69d 100644 --- a/linden/indra/llwindow/lldxhardware.h +++ b/linden/indra/llwindow/lldxhardware.h @@ -2,6 +2,8 @@ * @file lldxhardware.h * @brief LLDXHardware definition * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDXHARDWARE_H diff --git a/linden/indra/llwindow/llgl.cpp b/linden/indra/llwindow/llgl.cpp index 2310684..35f20d3 100644 --- a/linden/indra/llwindow/llgl.cpp +++ b/linden/indra/llwindow/llgl.cpp @@ -2,6 +2,8 @@ * @file llgl.cpp * @brief LLGL implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // This file sets some global GL parameters, and implements some diff --git a/linden/indra/llwindow/llgl.h b/linden/indra/llwindow/llgl.h index c83ccb8..2a23a23 100644 --- a/linden/indra/llwindow/llgl.h +++ b/linden/indra/llwindow/llgl.h @@ -2,6 +2,8 @@ * @file llgl.h * @brief LLGL definition * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLGL_H diff --git a/linden/indra/llwindow/llglheaders.h b/linden/indra/llwindow/llglheaders.h index 1d815ee..b98c832 100644 --- a/linden/indra/llwindow/llglheaders.h +++ b/linden/indra/llwindow/llglheaders.h @@ -2,6 +2,8 @@ * @file llglheaders.h * @brief LLGL definitions * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLGLHEADERS_H diff --git a/linden/indra/llwindow/llglstates.h b/linden/indra/llwindow/llglstates.h index 887d099..cbe1300 100644 --- a/linden/indra/llwindow/llglstates.h +++ b/linden/indra/llwindow/llglstates.h @@ -2,6 +2,8 @@ * @file llglstates.h * @brief LLGL states definitions * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //THIS HEADER SHOULD ONLY BE INCLUDED FROM llgl.h diff --git a/linden/indra/llwindow/llglstubs.h b/linden/indra/llwindow/llglstubs.h index fbbcd1f..e070aa2 100644 --- a/linden/indra/llwindow/llglstubs.h +++ b/linden/indra/llwindow/llglstubs.h @@ -2,6 +2,8 @@ * @file llglstubs.h * @brief LLGL stubs header file * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ diff --git a/linden/indra/llwindow/llgltypes.h b/linden/indra/llwindow/llgltypes.h index d130a42..42050cf 100644 --- a/linden/indra/llwindow/llgltypes.h +++ b/linden/indra/llwindow/llgltypes.h @@ -2,6 +2,8 @@ * @file llgltypes.h * @brief LLGL definition * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLGLTYPES_H diff --git a/linden/indra/llwindow/llkeyboard.cpp b/linden/indra/llwindow/llkeyboard.cpp index 213fe85..23f3dc7 100644 --- a/linden/indra/llwindow/llkeyboard.cpp +++ b/linden/indra/llwindow/llkeyboard.cpp @@ -2,6 +2,8 @@ * @file llkeyboard.cpp * @brief Handler for assignable key bindings * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llwindow/llkeyboard.h b/linden/indra/llwindow/llkeyboard.h index 61ae2ea..55af6fe 100644 --- a/linden/indra/llwindow/llkeyboard.h +++ b/linden/indra/llwindow/llkeyboard.h @@ -2,6 +2,8 @@ * @file llkeyboard.h * @brief Handler for assignable key bindings * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLKEYBOARD_H diff --git a/linden/indra/llwindow/llkeyboardmacosx.cpp b/linden/indra/llwindow/llkeyboardmacosx.cpp index 6d06d53..74b64b4 100644 --- a/linden/indra/llwindow/llkeyboardmacosx.cpp +++ b/linden/indra/llwindow/llkeyboardmacosx.cpp @@ -2,6 +2,8 @@ * @file llkeyboardmacosx.cpp * @brief Handler for assignable key bindings * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #if LL_DARWIN diff --git a/linden/indra/llwindow/llkeyboardmacosx.h b/linden/indra/llwindow/llkeyboardmacosx.h index 899b011..d897faa 100644 --- a/linden/indra/llwindow/llkeyboardmacosx.h +++ b/linden/indra/llwindow/llkeyboardmacosx.h @@ -2,6 +2,8 @@ * @file llkeyboardmacosx.h * @brief Handler for assignable key bindings * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLKEYBOARDMACOSX_H diff --git a/linden/indra/llwindow/llkeyboardsdl.cpp b/linden/indra/llwindow/llkeyboardsdl.cpp index 027f6a4..d832506 100644 --- a/linden/indra/llwindow/llkeyboardsdl.cpp +++ b/linden/indra/llwindow/llkeyboardsdl.cpp @@ -2,6 +2,8 @@ * @file llkeyboardsdl.cpp * @brief Handler for assignable key bindings * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #if LL_SDL diff --git a/linden/indra/llwindow/llkeyboardsdl.h b/linden/indra/llwindow/llkeyboardsdl.h index 7546496..d3a08ed 100644 --- a/linden/indra/llwindow/llkeyboardsdl.h +++ b/linden/indra/llwindow/llkeyboardsdl.h @@ -2,6 +2,8 @@ * @file llkeyboardsdl.h * @brief Handler for assignable key bindings * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLKEYBOARDSDL_H diff --git a/linden/indra/llwindow/llkeyboardwin32.cpp b/linden/indra/llwindow/llkeyboardwin32.cpp index f9db941..a5e7f3b 100644 --- a/linden/indra/llwindow/llkeyboardwin32.cpp +++ b/linden/indra/llwindow/llkeyboardwin32.cpp @@ -2,6 +2,8 @@ * @file llkeyboardwin32.cpp * @brief Handler for assignable key bindings * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #if LL_WINDOWS diff --git a/linden/indra/llwindow/llkeyboardwin32.h b/linden/indra/llwindow/llkeyboardwin32.h index 33233c9..10eb4c1 100644 --- a/linden/indra/llwindow/llkeyboardwin32.h +++ b/linden/indra/llwindow/llkeyboardwin32.h @@ -2,6 +2,8 @@ * @file llkeyboardwin32.h * @brief Handler for assignable key bindings * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLKEYBOARDWIN32_H diff --git a/linden/indra/llwindow/llmousehandler.h b/linden/indra/llwindow/llmousehandler.h index 3091920..057c75e 100644 --- a/linden/indra/llwindow/llmousehandler.h +++ b/linden/indra/llwindow/llmousehandler.h @@ -2,6 +2,8 @@ * @file llmousehandler.h * @brief LLMouseHandler class definition * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_MOUSEHANDLER_H diff --git a/linden/indra/llwindow/llwindow.cpp b/linden/indra/llwindow/llwindow.cpp index faa5e61..e845afe 100644 --- a/linden/indra/llwindow/llwindow.cpp +++ b/linden/indra/llwindow/llwindow.cpp @@ -2,6 +2,8 @@ * @file llwindow.cpp * @brief Basic graphical window class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llwindow/llwindow.h b/linden/indra/llwindow/llwindow.h index 1016bce..4db2c81 100644 --- a/linden/indra/llwindow/llwindow.h +++ b/linden/indra/llwindow/llwindow.h @@ -2,6 +2,8 @@ * @file llwindow.h * @brief Basic graphical window class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLWINDOW_H @@ -220,7 +223,7 @@ public: // control platform's Language Text Input mechanisms. virtual void allowLanguageTextInput( BOOL b ) {}; - virtual void setLanguageTextInput( LLCoordWindow pos ) {}; + virtual void setLanguageTextInput( const LLCoordGL & pos ) {}; protected: LLWindow(BOOL fullscreen, U32 flags); diff --git a/linden/indra/llwindow/llwindowheadless.cpp b/linden/indra/llwindow/llwindowheadless.cpp index 62306f1..1b55791 100644 --- a/linden/indra/llwindow/llwindowheadless.cpp +++ b/linden/indra/llwindow/llwindowheadless.cpp @@ -2,6 +2,8 @@ * @file llwindowheadless.cpp * @brief Headless implementation of LLWindow class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llwindow/llwindowheadless.h b/linden/indra/llwindow/llwindowheadless.h index c474a5a..4962cf7 100644 --- a/linden/indra/llwindow/llwindowheadless.h +++ b/linden/indra/llwindow/llwindowheadless.h @@ -2,6 +2,8 @@ * @file llwindowheadless.h * @brief Headless definition of LLWindow class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLWINDOWHEADLESS_H diff --git a/linden/indra/llwindow/llwindowlinux.cpp b/linden/indra/llwindow/llwindowlinux.cpp index 79f4d48..80da7e2 100644 --- a/linden/indra/llwindow/llwindowlinux.cpp +++ b/linden/indra/llwindow/llwindowlinux.cpp @@ -2,6 +2,8 @@ * @file llwindowlinux.cpp * @brief Platform-dependent implementation of llwindow * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #if LL_LINUX diff --git a/linden/indra/llwindow/llwindowlinux.h b/linden/indra/llwindow/llwindowlinux.h index 0465ef4..e7bcf4e 100644 --- a/linden/indra/llwindow/llwindowlinux.h +++ b/linden/indra/llwindow/llwindowlinux.h @@ -2,6 +2,8 @@ * @file llwindowlinux.h * @brief Linux implementation of LLWindow class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLWINDOWWIN32_H diff --git a/linden/indra/llwindow/llwindowmacosx-objc.h b/linden/indra/llwindow/llwindowmacosx-objc.h index d17fa61..a5c9e7a 100644 --- a/linden/indra/llwindow/llwindowmacosx-objc.h +++ b/linden/indra/llwindow/llwindowmacosx-objc.h @@ -3,6 +3,8 @@ * @brief Prototypes for functions shared between llwindowmacosx.cpp * and llwindowmacosx-objc.mm. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ diff --git a/linden/indra/llwindow/llwindowmacosx-objc.mm b/linden/indra/llwindow/llwindowmacosx-objc.mm index 241f821..b68ea8e 100644 --- a/linden/indra/llwindow/llwindowmacosx-objc.mm +++ b/linden/indra/llwindow/llwindowmacosx-objc.mm @@ -3,6 +3,8 @@ * @brief Definition of functions shared between llwindowmacosx.cpp * and llwindowmacosx-objc.mm. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include diff --git a/linden/indra/llwindow/llwindowmacosx.cpp b/linden/indra/llwindow/llwindowmacosx.cpp index 021d7a4..2724cb5 100644 --- a/linden/indra/llwindow/llwindowmacosx.cpp +++ b/linden/indra/llwindow/llwindowmacosx.cpp @@ -2,6 +2,8 @@ * @file llwindowmacosx.cpp * @brief Platform-dependent implementation of llwindow * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #if LL_DARWIN diff --git a/linden/indra/llwindow/llwindowmacosx.h b/linden/indra/llwindow/llwindowmacosx.h index 01b9303..ee3019b 100644 --- a/linden/indra/llwindow/llwindowmacosx.h +++ b/linden/indra/llwindow/llwindowmacosx.h @@ -2,6 +2,8 @@ * @file llwindowmacosx.h * @brief Mac implementation of LLWindow class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLWINDOWMACOSX_H diff --git a/linden/indra/llwindow/llwindowmesaheadless.cpp b/linden/indra/llwindow/llwindowmesaheadless.cpp index f10d7cd..f32ca01 100644 --- a/linden/indra/llwindow/llwindowmesaheadless.cpp +++ b/linden/indra/llwindow/llwindowmesaheadless.cpp @@ -2,6 +2,8 @@ * @file llwindowmesaheadless.cpp * @brief Platform-dependent implementation of llwindow * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #if LL_MESA_HEADLESS diff --git a/linden/indra/llwindow/llwindowmesaheadless.h b/linden/indra/llwindow/llwindowmesaheadless.h index f0ad50e..fe91a2d 100644 --- a/linden/indra/llwindow/llwindowmesaheadless.h +++ b/linden/indra/llwindow/llwindowmesaheadless.h @@ -2,6 +2,8 @@ * @file llwindowmesaheadless.h * @brief Windows implementation of LLWindow class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLWINDOWMESAHEADLESS_H diff --git a/linden/indra/llwindow/llwindowsdl.cpp b/linden/indra/llwindow/llwindowsdl.cpp index 9756e09..ad39c84 100644 --- a/linden/indra/llwindow/llwindowsdl.cpp +++ b/linden/indra/llwindow/llwindowsdl.cpp @@ -2,6 +2,8 @@ * @file llwindowsdl.cpp * @brief SDL implementation of LLWindow class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #if LL_SDL @@ -2035,10 +2038,6 @@ void LLWindowSDL::gatherInput() if (SDLCheckGrabbyKeys(event.key.keysym.sym, FALSE) == 0) SDLReallyCaptureInput(FALSE); // part of the fix for SL-13243 - // This is a testing hack to pop up a dialog when 4 is pressed - //if (event.key.keysym.sym == SDLK_4) - //OSMessageBox("a whole bunch of text goes right here, whee! test test test.", "this is the title!", OSMB_YESNO); - gKeyboard->handleKeyUp(event.key.keysym.sym, event.key.keysym.mod); break; @@ -2119,9 +2118,9 @@ void LLWindowSDL::gatherInput() else if (event.button.button == SDL_BUTTON_RIGHT) // right ... yes, it's 3, not 2, in SDL... mCallbacks->handleRightMouseUp(this, openGlCoord, mask); else if (event.button.button == SDL_BUTTON_MIDDLE) // middle - { - mCallbacks->handleMiddleMouseUp(this, openGlCoord, mask); - } + { + mCallbacks->handleMiddleMouseUp(this, openGlCoord, mask); + } // don't handle mousewheel here... break; @@ -2175,18 +2174,18 @@ void LLWindowSDL::gatherInput() } if (event.active.state & SDL_APPACTIVE) { - // Change in iconification/minimization state. - if ((!event.active.gain) != mIsMinimized) - { - mCallbacks->handleActivate(this, !!event.active.gain); - llinfos << "SDL deiconification state switched to " << BOOL(event.active.gain) << llendl; - - mIsMinimized = (!event.active.gain); - } - else - { - llinfos << "Ignored bogus redundant SDL deiconification state switch to " << BOOL(event.active.gain) << llendl; - } + // Change in iconification/minimization state. + if ((!event.active.gain) != mIsMinimized) + { + mCallbacks->handleActivate(this, !!event.active.gain); + llinfos << "SDL deiconification state switched to " << BOOL(event.active.gain) << llendl; + + mIsMinimized = (!event.active.gain); + } + else + { + llinfos << "Ignored bogus redundant SDL deiconification state switch to " << BOOL(event.active.gain) << llendl; + } } break; @@ -2713,6 +2712,7 @@ void spawn_web_browser(const char* escaped_url) cmd += "launch_url.sh"; char* const argv[] = {(char*)cmd.c_str(), (char*)escaped_url, NULL}; + fflush(NULL); pid_t pid = fork(); if (pid == 0) { // child diff --git a/linden/indra/llwindow/llwindowsdl.h b/linden/indra/llwindow/llwindowsdl.h index 2e75239..aa331ed 100644 --- a/linden/indra/llwindow/llwindowsdl.h +++ b/linden/indra/llwindow/llwindowsdl.h @@ -2,6 +2,8 @@ * @file llwindowsdl.h * @brief SDL implementation of LLWindow class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLWINDOWSDL_H diff --git a/linden/indra/llwindow/llwindowsolaris.cpp b/linden/indra/llwindow/llwindowsolaris.cpp index 7e3c3e6..425e545 100644 --- a/linden/indra/llwindow/llwindowsolaris.cpp +++ b/linden/indra/llwindow/llwindowsolaris.cpp @@ -2,6 +2,8 @@ * @file fmodwrapper.cpp * @brief dummy source file for building a shared library to wrap libfmod.a * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #if LL_SOLARIS diff --git a/linden/indra/llwindow/llwindowsolaris.h b/linden/indra/llwindow/llwindowsolaris.h index 57aa9b9..7b43197 100644 --- a/linden/indra/llwindow/llwindowsolaris.h +++ b/linden/indra/llwindow/llwindowsolaris.h @@ -2,6 +2,8 @@ * @file fmodwrapper.cpp * @brief dummy source file for building a shared library to wrap libfmod.a * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLWINDOWSOLARIS_H diff --git a/linden/indra/llwindow/llwindowwin32.cpp b/linden/indra/llwindow/llwindowwin32.cpp index 3a41d01..bb99d4c 100644 --- a/linden/indra/llwindow/llwindowwin32.cpp +++ b/linden/indra/llwindow/llwindowwin32.cpp @@ -2,6 +2,8 @@ * @file llwindowwin32.cpp * @brief Platform-dependent implementation of llwindow * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -85,11 +88,10 @@ void show_window_creation_error(const char* title) //static BOOL LLWindowWin32::sIsClassRegistered = FALSE; -BOOL LLWindowWin32::sLanguageTextInputAllowed = TRUE; /* XXX */ -BOOL LLWindowWin32::sWinIMEOpened = FALSE; -HKL LLWindowWin32::sWinInputLocale; -DWORD LLWindowWin32::sWinIMEConversionMode; -DWORD LLWindowWin32::sWinIMESentenceMode; +BOOL LLWindowWin32::sLanguageTextInputAllowed = TRUE; +HKL LLWindowWin32::sWinInputLocale = 0; +DWORD LLWindowWin32::sWinIMEConversionMode = IME_CMODE_NATIVE; +DWORD LLWindowWin32::sWinIMESentenceMode = IME_SMODE_AUTOMATIC; // The following class LLWinImm delegates Windows IMM APIs. // We need this because some language versions of Windows, @@ -107,13 +109,15 @@ public: public: // Wrappers for IMM API. - static BOOL isIME(HKL hkl) { return sTheInstance.mImmIsIME(hkl); } - static HIMC getContext(HWND hwnd) { return sTheInstance.mImmGetContext(hwnd); } - static BOOL releaseContext(HWND hwnd, HIMC himc) { return sTheInstance.mImmReleaseContext(hwnd, himc); } - static BOOL getOpenStatus(HIMC himc) { return sTheInstance.mImmGetOpenStatus(himc); } - static BOOL setOpenStatus(HIMC himc, BOOL status) { return sTheInstance.mImmSetOpenStatus(himc, status); } - static BOOL getConversionStatus(HIMC himc, LPDWORD conversion, LPDWORD sentence) { return sTheInstance.mImmGetConversionStatus(himc, conversion, sentence); } - static BOOL setConversionStatus(HIMC himc, DWORD conversion, DWORD sentence) { return sTheInstance.mImmSetConversionStatus(himc, conversion, sentence); } + static BOOL isIME(HKL hkl); + static HIMC getContext(HWND hwnd); + static BOOL releaseContext(HWND hwnd, HIMC himc); + static BOOL getOpenStatus(HIMC himc); + static BOOL setOpenStatus(HIMC himc, BOOL status); + static BOOL getConversionStatus(HIMC himc, LPDWORD conversion, LPDWORD sentence); + static BOOL setConversionStatus(HIMC himc, DWORD conversion, DWORD sentence); + static BOOL getCompositionWindow(HIMC himc, LPCOMPOSITIONFORM form); + static BOOL setCompositionWindow(HIMC himc, LPCOMPOSITIONFORM form); private: LLWinImm(); @@ -128,6 +132,8 @@ private: BOOL (WINAPI *mImmSetOpenStatus)(HIMC, BOOL); BOOL (WINAPI *mImmGetConversionStatus)(HIMC, LPDWORD, LPDWORD); BOOL (WINAPI *mImmSetConversionStatus)(HIMC, DWORD, DWORD); + BOOL (WINAPI *mImmGetCompostitionWindow)(HIMC, LPCOMPOSITIONFORM); + BOOL (WINAPI *mImmSetCompostitionWindow)(HIMC, LPCOMPOSITIONFORM); private: HMODULE mHImmDll; @@ -136,8 +142,13 @@ private: LLWinImm LLWinImm::sTheInstance; -LLWinImm::LLWinImm() +LLWinImm::LLWinImm() : mHImmDll(NULL) { + // Check system metrics + if ( !GetSystemMetrics( SM_DBCSENABLED ) ) + return; + + mHImmDll = LoadLibraryA("Imm32"); if (mHImmDll != NULL) { @@ -148,13 +159,18 @@ LLWinImm::LLWinImm() mImmSetOpenStatus = (BOOL (WINAPI *)(HIMC, BOOL)) GetProcAddress(mHImmDll, "ImmSetOpenStatus"); mImmGetConversionStatus = (BOOL (WINAPI *)(HIMC, LPDWORD, LPDWORD)) GetProcAddress(mHImmDll, "ImmGetConversionStatus"); mImmSetConversionStatus = (BOOL (WINAPI *)(HIMC, DWORD, DWORD)) GetProcAddress(mHImmDll, "ImmSetConversionStatus"); + mImmGetCompostitionWindow = (BOOL (WINAPI *)(HIMC, LPCOMPOSITIONFORM)) GetProcAddress(mHImmDll, "ImmGetCompositionWindow"); + mImmSetCompostitionWindow = (BOOL (WINAPI *)(HIMC, LPCOMPOSITIONFORM)) GetProcAddress(mHImmDll, "ImmSetCompositionWindow"); + if (mImmIsIME == NULL || mImmGetContext == NULL || mImmReleaseContext == NULL || mImmGetOpenStatus == NULL || mImmSetOpenStatus == NULL || mImmGetConversionStatus == NULL || - mImmSetConversionStatus == NULL) + mImmSetConversionStatus == NULL || + mImmGetCompostitionWindow == NULL || + mImmSetCompostitionWindow == NULL) { // If any of the above API entires are not found, we can't use IMM API. // So, turn off the IMM support. We should log some warning message in @@ -165,10 +181,96 @@ LLWinImm::LLWinImm() // is one of disadvantages to use static constraction to DLL loading. FreeLibrary(mHImmDll); mHImmDll = NULL; + + // If we unload the library, make sure all the function pointers are cleared + mImmIsIME = NULL; + mImmGetContext = NULL; + mImmReleaseContext = NULL; + mImmGetOpenStatus = NULL; + mImmSetOpenStatus = NULL; + mImmGetConversionStatus = NULL; + mImmSetConversionStatus = NULL; + mImmGetCompostitionWindow = NULL; + mImmSetCompostitionWindow = NULL; } } } + +// static +BOOL LLWinImm::isIME(HKL hkl) +{ + if ( sTheInstance.mImmIsIME ) + return sTheInstance.mImmIsIME(hkl); + return FALSE; +} + +// static +HIMC LLWinImm::getContext(HWND hwnd) +{ + if ( sTheInstance.mImmGetContext ) + return sTheInstance.mImmGetContext(hwnd); + return 0; +} + +//static +BOOL LLWinImm::releaseContext(HWND hwnd, HIMC himc) +{ + if ( sTheInstance.mImmIsIME ) + return sTheInstance.mImmReleaseContext(hwnd, himc); + return FALSE; +} + +// static +BOOL LLWinImm::getOpenStatus(HIMC himc) +{ + if ( sTheInstance.mImmGetOpenStatus ) + return sTheInstance.mImmGetOpenStatus(himc); + return FALSE; +} + +// static +BOOL LLWinImm::setOpenStatus(HIMC himc, BOOL status) +{ + if ( sTheInstance.mImmSetOpenStatus ) + return sTheInstance.mImmSetOpenStatus(himc, status); + return FALSE; +} + +// static +BOOL LLWinImm::getConversionStatus(HIMC himc, LPDWORD conversion, LPDWORD sentence) +{ + if ( sTheInstance.mImmGetConversionStatus ) + return sTheInstance.mImmGetConversionStatus(himc, conversion, sentence); + return FALSE; +} + +// static +BOOL LLWinImm::setConversionStatus(HIMC himc, DWORD conversion, DWORD sentence) +{ + if ( sTheInstance.mImmSetConversionStatus ) + return sTheInstance.mImmSetConversionStatus(himc, conversion, sentence); + return FALSE; +} + +// static +BOOL LLWinImm::getCompositionWindow(HIMC himc, LPCOMPOSITIONFORM form) +{ + if ( sTheInstance.mImmGetCompostitionWindow ) + return sTheInstance.mImmGetCompostitionWindow(himc, form); + return FALSE; +} + +// static +BOOL LLWinImm::setCompositionWindow(HIMC himc, LPCOMPOSITIONFORM form) +{ + if ( sTheInstance.mImmSetCompostitionWindow ) + return sTheInstance.mImmSetCompostitionWindow(himc, form); + return FALSE; +} + + +// ---------------------------------------------------------------------------------------- LLWinImm::~LLWinImm() { if (mHImmDll != NULL) @@ -3222,53 +3324,74 @@ void LLWindowWin32::focusClient() void LLWindowWin32::allowLanguageTextInput(BOOL b) { - if (b == sLanguageTextInputAllowed || !LLWinImm::isAvailable()) + if ( !LLWinImm::isAvailable() ) { - /* Not actually allowing/disallowing. Do nothing. */ return; } sLanguageTextInputAllowed = b; if (b) { - /* Allowing: Restore the previous IME status, - so that the user has a feeling that the previous - text input continues naturally. Be careful, however, - the IME status is meaningful only during the user keeps - using same Input Locale (aka Keyboard Layout). */ - if (sWinIMEOpened && GetKeyboardLayout(0) == sWinInputLocale) + // Allowing: Restore the previous IME status, so that the user has a feeling that the previous + // text input continues naturally. Be careful, however, the IME status is meaningful only during the user keeps + // using same Input Locale (aka Keyboard Layout). + HIMC himc = LLWinImm::getContext(mWindowHandle); + LLWinImm::setOpenStatus(himc, TRUE); + if (GetKeyboardLayout(0) == sWinInputLocale && sWinIMEConversionMode != IME_CMODE_RESERVED) { - HIMC himc = LLWinImm::getContext(mWindowHandle); - LLWinImm::setOpenStatus(himc, TRUE); LLWinImm::setConversionStatus(himc, sWinIMEConversionMode, sWinIMESentenceMode); - LLWinImm::releaseContext(mWindowHandle, himc); + sWinIMEConversionMode = IME_CMODE_RESERVED; // Set saved state so we won't do this repeatedly } + LLWinImm::releaseContext(mWindowHandle, himc); } else { - /* Disallowing: Turn off the IME so that succeeding - key events bypass IME and come to us directly. - However, do it after saving the current IME - status. We need to restore the status when - allowing language text input again. */ + // Disallowing: Turn off the IME so that succeeding key events bypass IME and come to us directly. + // However, do it after saving the current IME status. We need to restore the status when + // allowing language text input again. sWinInputLocale = GetKeyboardLayout(0); - sWinIMEOpened = LLWinImm::isIME(sWinInputLocale); - if (sWinIMEOpened) + if ( LLWinImm::isIME(sWinInputLocale) ) { HIMC himc = LLWinImm::getContext(mWindowHandle); - sWinIMEOpened = LLWinImm::getOpenStatus(himc); - if (sWinIMEOpened) + if ( LLWinImm::getOpenStatus(himc) ) { LLWinImm::getConversionStatus(himc, &sWinIMEConversionMode, &sWinIMESentenceMode); - /* We need both ImmSetConversionStatus and ImmSetOpenStatus here - to surely disable IME's keyboard hooking, because Some IME reacts - only on the former and some other on the latter... */ + // We need both ImmSetConversionStatus and ImmSetOpenStatus here to surely disable IME's + // keyboard hooking, because Some IME reacts only on the former and some other on the latter... LLWinImm::setConversionStatus(himc, IME_CMODE_NOCONVERSION, sWinIMESentenceMode); LLWinImm::setOpenStatus(himc, FALSE); } LLWinImm::releaseContext(mWindowHandle, himc); + } + } + +} + + +// Put the IME window at the right place (near current text input). Point coordinates should be the top of the current text line. +void LLWindowWin32::setLanguageTextInput( const LLCoordGL & position ) +{ + if (sLanguageTextInputAllowed && LLWinImm::isAvailable()) + { + HIMC himc = LLWinImm::getContext(mWindowHandle); + + LLCoordWindow win_pos; + convertCoords( position, &win_pos ); + + if ( win_pos.mX >= 0 && win_pos.mY >= 0 ) + { + COMPOSITIONFORM ime_form; + memset( &ime_form, 0, sizeof(ime_form) ); + ime_form.dwStyle = CFS_POINT; + ime_form.ptCurrentPos.x = win_pos.mX; + ime_form.ptCurrentPos.y = win_pos.mY; + + LLWinImm::setCompositionWindow( himc, &ime_form ); } + + LLWinImm::releaseContext(mWindowHandle, himc); + } } diff --git a/linden/indra/llwindow/llwindowwin32.h b/linden/indra/llwindow/llwindowwin32.h index 0f0cf7c..938ece9 100644 --- a/linden/indra/llwindow/llwindowwin32.h +++ b/linden/indra/llwindow/llwindowwin32.h @@ -2,6 +2,8 @@ * @file llwindowwin32.h * @brief Windows implementation of LLWindow class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLWINDOWWIN32_H @@ -107,6 +110,7 @@ public: /*virtual*/ void focusClient(); /*virtual*/ void allowLanguageTextInput(BOOL b); + /*virtual*/ void setLanguageTextInput( const LLCoordGL & pos ); protected: LLWindowWin32( @@ -176,11 +180,10 @@ protected: BOOL mMousePositionModified; BOOL mInputProcessingPaused; - // The following five variables are for Language Text Input control. + // The following variables are for Language Text Input control. // They are all static, since one context is shared by all LLWindowWin32 // instances. static BOOL sLanguageTextInputAllowed; - static BOOL sWinIMEOpened; static HKL sWinInputLocale; static DWORD sWinIMEConversionMode; static DWORD sWinIMESentenceMode; diff --git a/linden/indra/llxml/llcontrol.cpp b/linden/indra/llxml/llcontrol.cpp index 3a1c806..30c6394 100644 --- a/linden/indra/llxml/llcontrol.cpp +++ b/linden/indra/llxml/llcontrol.cpp @@ -2,6 +2,8 @@ * @file llcontrol.cpp * @brief Holds global state for viewer. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llxml/llcontrol.h b/linden/indra/llxml/llcontrol.h index a46438a..849118a 100644 --- a/linden/indra/llxml/llcontrol.h +++ b/linden/indra/llxml/llcontrol.h @@ -2,6 +2,8 @@ * @file llcontrol.h * @brief A mechanism for storing "control state" for a program * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCONTROL_H diff --git a/linden/indra/llxml/llxmlnode.cpp b/linden/indra/llxml/llxmlnode.cpp index 8a267a5..4501daf 100644 --- a/linden/indra/llxml/llxmlnode.cpp +++ b/linden/indra/llxml/llxmlnode.cpp @@ -3,6 +3,8 @@ * @author Tom Yedwab * @brief LLXMLNode implementation * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llxml/llxmlnode.h b/linden/indra/llxml/llxmlnode.h index e0e8f2f..7c22157 100644 --- a/linden/indra/llxml/llxmlnode.h +++ b/linden/indra/llxml/llxmlnode.h @@ -2,6 +2,8 @@ * @file llxmlnode.h * @brief LLXMLNode definition * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLXMLNODE_H @@ -129,8 +132,8 @@ public: LLXMLNodePtr& node, LLXMLNodePtr& update_node); static void writeHeaderToFile(FILE *fOut); - void writeToFile(FILE *fOut, LLString indent = ""); - void writeToOstream(std::ostream& output_stream, const LLString& indent = ""); + void writeToFile(FILE *fOut, LLString indent = LLString()); + void writeToOstream(std::ostream& output_stream, const LLString& indent = LLString()); // Utility void findName(const LLString& name, LLXMLNodeList &results); diff --git a/linden/indra/llxml/llxmlparser.cpp b/linden/indra/llxml/llxmlparser.cpp index 5f931d9..10e6f3f 100644 --- a/linden/indra/llxml/llxmlparser.cpp +++ b/linden/indra/llxml/llxmlparser.cpp @@ -2,6 +2,8 @@ * @file llxmlparser.cpp * @brief LLXmlParser implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // llxmlparser.cpp diff --git a/linden/indra/llxml/llxmlparser.h b/linden/indra/llxml/llxmlparser.h index 7904175..d86af69 100644 --- a/linden/indra/llxml/llxmlparser.h +++ b/linden/indra/llxml/llxmlparser.h @@ -2,6 +2,8 @@ * @file llxmlparser.h * @brief LLXmlParser class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLXMLPARSER_H diff --git a/linden/indra/llxml/llxmltree.cpp b/linden/indra/llxml/llxmltree.cpp index 81bc34a..a036b87 100644 --- a/linden/indra/llxml/llxmltree.cpp +++ b/linden/indra/llxml/llxmltree.cpp @@ -2,6 +2,8 @@ * @file llxmltree.cpp * @brief LLXmlTree implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/llxml/llxmltree.h b/linden/indra/llxml/llxmltree.h index 32f5389..d492665 100644 --- a/linden/indra/llxml/llxmltree.h +++ b/linden/indra/llxml/llxmltree.h @@ -3,6 +3,8 @@ * @author Aaron Yonas, Richard Nelson * @brief LLXmlTree class definition * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLXMLTREE_H diff --git a/linden/indra/lscript/lscript_alloc.h b/linden/indra/lscript/lscript_alloc.h index 8179446..d90cc14 100644 --- a/linden/indra/lscript/lscript_alloc.h +++ b/linden/indra/lscript/lscript_alloc.h @@ -2,6 +2,8 @@ * @file lscript_alloc.h * @brief General heap management for scripting system * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LSCRIPT_ALLOC_H @@ -32,11 +35,8 @@ // Under gcc 2.9, the manual is unclear if comments can appear above #ifndef // Under gcc 3, the manual explicitly states comments can appear above the #ifndef -#include "stdtypes.h" #include "lscript_byteconvert.h" #include "lscript_library.h" -#include "llrand.h" -#include void reset_hp_to_safe_spot(const U8 *buffer); diff --git a/linden/indra/lscript/lscript_byteconvert.h b/linden/indra/lscript/lscript_byteconvert.h index 06d494e..6d0e2d0 100644 --- a/linden/indra/lscript/lscript_byteconvert.h +++ b/linden/indra/lscript/lscript_byteconvert.h @@ -2,6 +2,8 @@ * @file lscript_byteconvert.h * @brief Shared code for compiler and assembler for LSL * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // data shared between compiler/assembler @@ -781,9 +784,17 @@ inline S32 get_state_event_opcoode_start(U8 *stream, S32 state, LSCRIPTStateEven major_version = LSL2_MAJOR_VERSION_TWO; state_offset_offset = sr + LSCRIPTDataSize[LST_INTEGER] + LSCRIPTDataSize[LST_INTEGER]*3*state; } + if ( state_offset_offset < 0 || state_offset_offset > TOP_OF_MEMORY ) + { + return -1; + } // get the actual position in memory of the desired state S32 state_offset = sr + bytestream2integer(stream, state_offset_offset); + if ( state_offset < 0 || state_offset > TOP_OF_MEMORY ) + { + return -1; + } // save that value S32 state_offset_base = state_offset; @@ -793,18 +804,32 @@ inline S32 get_state_event_opcoode_start(U8 *stream, S32 state, LSCRIPTStateEven // get the location of the event offset S32 event_offset = event_jump_offset + LSCRIPTDataSize[LST_INTEGER]*2*get_event_handler_jump_position(get_event_register(stream, LREG_ER, major_version), event); + if ( event_offset < 0 || event_offset > TOP_OF_MEMORY ) + { + return -1; + } // now, jump to the event S32 event_start = bytestream2integer(stream, event_offset); + if ( event_start < 0 || event_start > TOP_OF_MEMORY ) + { + return -1; + } event_start += event_jump_offset; S32 event_start_original = event_start; // now skip past the parameters S32 opcode_offset = bytestream2integer(stream, event_start); + if ( opcode_offset < 0 || opcode_offset > TOP_OF_MEMORY ) + { + return -1; + } + return opcode_offset + event_start_original; } + inline U64 get_handled_events(U8 *stream, S32 state) { U64 retvalue = 0; @@ -829,6 +854,7 @@ inline U64 get_handled_events(U8 *stream, S32 state) return retvalue; } +// Returns -1 on error inline S32 get_event_stack_size(U8 *stream, S32 state, LSCRIPTStateEventType event) { // get the start of the state table @@ -849,21 +875,39 @@ inline S32 get_event_stack_size(U8 *stream, S32 state, LSCRIPTStateEventType eve state_offset_offset = sr + LSCRIPTDataSize[LST_INTEGER] + LSCRIPTDataSize[LST_INTEGER]*3*state; } + if ( state_offset_offset < 0 || state_offset_offset > TOP_OF_MEMORY ) + { + return -1; + } + S32 state_offset = bytestream2integer(stream, state_offset_offset); state_offset += sr; state_offset_offset = state_offset; + if ( state_offset_offset < 0 || state_offset_offset > TOP_OF_MEMORY ) + { + return -1; + } // skip to jump table S32 jump_table = bytestream2integer(stream, state_offset_offset); jump_table += state_offset; + if ( jump_table < 0 || jump_table > TOP_OF_MEMORY ) + { + return -1; + } // get the position of the jump to the desired state S32 stack_size_offset = jump_table + LSCRIPTDataSize[LST_INTEGER]*2*get_event_handler_jump_position(get_event_register(stream, LREG_ER, major_version), event) + LSCRIPTDataSize[LST_INTEGER]; // get the handled events S32 stack_size = bytestream2integer(stream, stack_size_offset); + if ( stack_size < 0 || stack_size > TOP_OF_MEMORY ) + { + return -1; + } + return stack_size; } diff --git a/linden/indra/lscript/lscript_byteformat.h b/linden/indra/lscript/lscript_byteformat.h index 2feee9f..4e8f13f 100644 --- a/linden/indra/lscript/lscript_byteformat.h +++ b/linden/indra/lscript/lscript_byteformat.h @@ -2,6 +2,8 @@ * @file lscript_byteformat.h * @brief Shared code between compiler and assembler and LSL * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LSCRIPT_BYTEFORMAT_H diff --git a/linden/indra/lscript/lscript_compile/indra.l b/linden/indra/lscript/lscript_compile/indra.l index de5ba11..69e77fb 100644 --- a/linden/indra/lscript/lscript_compile/indra.l +++ b/linden/indra/lscript/lscript_compile/indra.l @@ -9,13 +9,15 @@ FS (f|F) %p 5000 %{ -#include -#include "stdtypes.h" +#include "linden_common.h" +// Deal with the fact that lex/yacc generates unreachable code +#ifdef LL_WINDOWS +#pragma warning (disable : 4702) // warning C4702: unreachable code +#endif // LL_WINDOWS #include "llmath.h" #include "lscript_tree.h" #include "lscript_typecheck.h" #include "lscript_resource.h" -#include "llfile.h" #if LL_WINDOWS #include "ytab.h" #else diff --git a/linden/indra/lscript/lscript_compile/indra.y b/linden/indra/lscript/lscript_compile/indra.y index 56f40c9..d10cbfe 100644 --- a/linden/indra/lscript/lscript_compile/indra.y +++ b/linden/indra/lscript/lscript_compile/indra.y @@ -1,7 +1,7 @@ %{ - #include "stdtypes.h" + #include "linden_common.h" #include "lscript_tree.h" - + #ifdef __cplusplus extern "C" { #endif @@ -16,6 +16,7 @@ #endif #ifdef LL_WINDOWS + #pragma warning (disable : 4702) // warning C4702: unreachable code #pragma warning( disable : 4065 ) // warning: switch statement contains 'default' but no 'case' labels #endif diff --git a/linden/indra/lscript/lscript_compile/lscript_alloc.cpp b/linden/indra/lscript/lscript_compile/lscript_alloc.cpp index 9298524..873fc36 100644 --- a/linden/indra/lscript/lscript_compile/lscript_alloc.cpp +++ b/linden/indra/lscript/lscript_compile/lscript_alloc.cpp @@ -2,6 +2,8 @@ * @file lscript_alloc.cpp * @brief Allocation tracking * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,5 +26,6 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ diff --git a/linden/indra/lscript/lscript_compile/lscript_bytecode.cpp b/linden/indra/lscript/lscript_compile/lscript_bytecode.cpp index 0d75eee..c41c34c 100644 --- a/linden/indra/lscript/lscript_compile/lscript_bytecode.cpp +++ b/linden/indra/lscript/lscript_compile/lscript_bytecode.cpp @@ -2,6 +2,8 @@ * @file lscript_bytecode.cpp * @brief classes to build actual bytecode * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/lscript/lscript_compile/lscript_bytecode.h b/linden/indra/lscript/lscript_compile/lscript_bytecode.h index 2dd4719..8db031a 100644 --- a/linden/indra/lscript/lscript_compile/lscript_bytecode.h +++ b/linden/indra/lscript/lscript_compile/lscript_bytecode.h @@ -2,6 +2,8 @@ * @file lscript_bytecode.h * @brief classes to build actual bytecode * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LSCRIPT_BYTECODE_H diff --git a/linden/indra/lscript/lscript_compile/lscript_error.cpp b/linden/indra/lscript/lscript_compile/lscript_error.cpp index d54bbb4..f4960fc 100644 --- a/linden/indra/lscript/lscript_compile/lscript_error.cpp +++ b/linden/indra/lscript/lscript_compile/lscript_error.cpp @@ -2,6 +2,8 @@ * @file lscript_error.cpp * @brief error reporting class and strings * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/lscript/lscript_compile/lscript_error.h b/linden/indra/lscript/lscript_compile/lscript_error.h index c795b0c..aba3932 100644 --- a/linden/indra/lscript/lscript_compile/lscript_error.h +++ b/linden/indra/lscript/lscript_compile/lscript_error.h @@ -2,6 +2,8 @@ * @file lscript_error.h * @brief error reporting class and strings * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,16 +26,14 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LSCRIPT_ERROR_H #define LL_LSCRIPT_ERROR_H -#include -#include "stdtypes.h" #include "lscript_scope.h" - typedef enum e_lscript_compile_pass { LSCP_INVALID, diff --git a/linden/indra/lscript/lscript_compile/lscript_heap.cpp b/linden/indra/lscript/lscript_compile/lscript_heap.cpp index 33c52e7..7242b72 100644 --- a/linden/indra/lscript/lscript_compile/lscript_heap.cpp +++ b/linden/indra/lscript/lscript_compile/lscript_heap.cpp @@ -2,6 +2,8 @@ * @file lscript_heap.cpp * @brief classes to manage script heap * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #if 0 diff --git a/linden/indra/lscript/lscript_compile/lscript_heap.h b/linden/indra/lscript/lscript_compile/lscript_heap.h index 2c55abc..a06466a 100644 --- a/linden/indra/lscript/lscript_compile/lscript_heap.h +++ b/linden/indra/lscript/lscript_compile/lscript_heap.h @@ -2,6 +2,8 @@ * @file lscript_heap.h * @brief classes to manage script heap * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #if 0 diff --git a/linden/indra/lscript/lscript_compile/lscript_resource.cpp b/linden/indra/lscript/lscript_compile/lscript_resource.cpp index 4747524..0e01385 100644 --- a/linden/indra/lscript/lscript_compile/lscript_resource.cpp +++ b/linden/indra/lscript/lscript_compile/lscript_resource.cpp @@ -2,6 +2,8 @@ * @file lscript_resource.cpp * @brief resource determination prior to assembly * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/lscript/lscript_compile/lscript_resource.h b/linden/indra/lscript/lscript_compile/lscript_resource.h index 91e9e70..80e6c83 100644 --- a/linden/indra/lscript/lscript_compile/lscript_resource.h +++ b/linden/indra/lscript/lscript_compile/lscript_resource.h @@ -2,6 +2,8 @@ * @file lscript_resource.h * @brief resource determination prior to assembly * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,13 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LSCRIPT_RESOURCE_H #define LL_LSCRIPT_RESOURCE_H -#include -#include "stdtypes.h" #include "lscript_scope.h" void init_temp_jumps(); diff --git a/linden/indra/lscript/lscript_compile/lscript_scope.cpp b/linden/indra/lscript/lscript_compile/lscript_scope.cpp index 747327b..4d00661 100644 --- a/linden/indra/lscript/lscript_compile/lscript_scope.cpp +++ b/linden/indra/lscript/lscript_compile/lscript_scope.cpp @@ -2,6 +2,8 @@ * @file lscript_scope.cpp * @brief builds nametable and checks scope * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/lscript/lscript_compile/lscript_scope.h b/linden/indra/lscript/lscript_compile/lscript_scope.h index 2b82d4b..c55d995 100644 --- a/linden/indra/lscript/lscript_compile/lscript_scope.h +++ b/linden/indra/lscript/lscript_compile/lscript_scope.h @@ -2,6 +2,8 @@ * @file lscript_scope.h * @brief builds nametable and checks scope * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LSCRIPT_SCOPE_H diff --git a/linden/indra/lscript/lscript_compile/lscript_tree.cpp b/linden/indra/lscript/lscript_compile/lscript_tree.cpp index 075418d..cad6fc2 100644 --- a/linden/indra/lscript/lscript_compile/lscript_tree.cpp +++ b/linden/indra/lscript/lscript_compile/lscript_tree.cpp @@ -2,6 +2,8 @@ * @file lscript_tree.cpp * @brief implements methods for lscript_tree.h classes * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // TO DO: Move print functionality from .h file to here diff --git a/linden/indra/lscript/lscript_compile/lscript_tree.h b/linden/indra/lscript/lscript_compile/lscript_tree.h index a70db87..fee648e 100644 --- a/linden/indra/lscript/lscript_compile/lscript_tree.h +++ b/linden/indra/lscript/lscript_compile/lscript_tree.h @@ -2,6 +2,8 @@ * @file lscript_tree.h * @brief provides the classes required to build lscript's abstract syntax tree and symbol table * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,13 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LSCRIPT_TREE_H #define LL_LSCRIPT_TREE_H -#include -#include "stdtypes.h" #include "v3math.h" #include "llquaternion.h" #include "linked_lists.h" diff --git a/linden/indra/lscript/lscript_compile/lscript_typecheck.cpp b/linden/indra/lscript/lscript_compile/lscript_typecheck.cpp index 9fa7720..847a54e 100644 --- a/linden/indra/lscript/lscript_compile/lscript_typecheck.cpp +++ b/linden/indra/lscript/lscript_compile/lscript_typecheck.cpp @@ -2,6 +2,8 @@ * @file lscript_typecheck.cpp * @brief typechecks script * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/lscript/lscript_compile/lscript_typecheck.h b/linden/indra/lscript/lscript_compile/lscript_typecheck.h index c10d11b..0ebae2d 100644 --- a/linden/indra/lscript/lscript_compile/lscript_typecheck.h +++ b/linden/indra/lscript/lscript_compile/lscript_typecheck.h @@ -2,6 +2,8 @@ * @file lscript_typecheck.h * @brief typechecks script * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LSCRIPT_TYPECHECK_H diff --git a/linden/indra/lscript/lscript_execute.h b/linden/indra/lscript/lscript_execute.h index 82109fd..1e11d32 100644 --- a/linden/indra/lscript/lscript_execute.h +++ b/linden/indra/lscript/lscript_execute.h @@ -2,6 +2,8 @@ * @file lscript_execute.h * @brief Classes to execute bytecode * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,12 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LSCRIPT_EXECUTE_H #define LL_LSCRIPT_EXECUTE_H -#include #include "lscript_byteconvert.h" #include "linked_lists.h" #include "lscript_library.h" @@ -379,6 +381,10 @@ public: LLScriptEventData mEventData; static S64 sGlobalInstructionCount; + +private: + void recordBoundaryError( const LLUUID &id ); + void setStateEventOpcoodeStartSafely( S32 state, LSCRIPTStateEventType event, const LLUUID &id ); }; #endif diff --git a/linden/indra/lscript/lscript_execute/lscript_execute.cpp b/linden/indra/lscript/lscript_execute/lscript_execute.cpp index 9e8be15..5bbbc47 100644 --- a/linden/indra/lscript/lscript_execute/lscript_execute.cpp +++ b/linden/indra/lscript/lscript_execute/lscript_execute.cpp @@ -2,6 +2,8 @@ * @file lscript_execute.cpp * @brief classes to execute bytecode * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" @@ -265,6 +268,32 @@ void LLScriptExecute::init() } + +// Utility routine for when there's a boundary error parsing bytecode +void LLScriptExecute::recordBoundaryError( const LLUUID &id ) +{ + set_fault(mBuffer, LSRF_BOUND_CHECK_ERROR); + llwarns << "Script boundary error for ID " << id << llendl; +} + + +// set IP to the event handler with some error checking +void LLScriptExecute::setStateEventOpcoodeStartSafely( S32 state, LSCRIPTStateEventType event, const LLUUID &id ) +{ + S32 opcode_start = get_state_event_opcoode_start( mBuffer, state, event ); + if ( opcode_start == -1 ) + { + recordBoundaryError( id ); + } + else + { + set_ip( mBuffer, opcode_start ); + } +} + + + + S32 lscript_push_variable(LLScriptLibData *data, U8 *buffer); U32 LLScriptExecute::run(BOOL b_print, const LLUUID &id, char **errorstr, BOOL &state_transition) @@ -373,14 +402,20 @@ U32 LLScriptExecute::run(BOOL b_print, const LLUUID &id, char **errorstr, BOOL & // now, push any additional stack space S32 additional_size = get_event_stack_size(mBuffer, current_state, LSTT_STATE_EXIT); - lscript_pusharge(mBuffer, additional_size); - - sp = get_register(mBuffer, LREG_SP); - sp += additional_size; - set_bp(mBuffer, sp); - // set IP to the event handler - S32 opcode_start = get_state_event_opcoode_start(mBuffer, current_state, LSTT_STATE_EXIT); - set_ip(mBuffer, opcode_start); + if ( additional_size == -1 ) + { + recordBoundaryError( id ); + } + else + { + lscript_pusharge(mBuffer, additional_size); + + sp = get_register(mBuffer, LREG_SP); + sp += additional_size; + set_bp(mBuffer, sp); + // set IP to the event handler + setStateEventOpcoodeStartSafely( current_state, LSTT_STATE_EXIT, id ); + } return NO_DELETE_FLAG; } } @@ -431,20 +466,27 @@ U32 LLScriptExecute::run(BOOL b_print, const LLUUID &id, char **errorstr, BOOL & current_events &= ~LSCRIPTStateBitField[event]; set_event_register(mBuffer, LREG_CE, current_events, major_version); // now, push any additional stack space - S32 additional_size = get_event_stack_size(mBuffer, current_state, event) - size; - lscript_pusharge(mBuffer, additional_size); + S32 additional_size = get_event_stack_size(mBuffer, current_state, event); + if ( additional_size == -1 ) + { // b_done will be set, so we'll exit the loop at the bottom + recordBoundaryError( id ); + } + else + { + additional_size -= size; + lscript_pusharge(mBuffer, additional_size); // now set the bp correctly - sp = get_register(mBuffer, LREG_SP); - sp += additional_size + size; - set_bp(mBuffer, sp); + sp = get_register(mBuffer, LREG_SP); + sp += additional_size + size; + set_bp(mBuffer, sp); // set IP to the function - S32 opcode_start = get_state_event_opcoode_start(mBuffer, current_state, event); - set_ip(mBuffer, opcode_start); + setStateEventOpcoodeStartSafely( current_state, event, id ); + } b_done = TRUE; } else if ( (current_events & LSCRIPTStateBitField[LSTT_REZ]) - &&(current_events & event_register)) + &&(current_events & event_register)) { for (eventdata = mEventData.mEventDataList.getFirstData(); eventdata; eventdata = mEventData.mEventDataList.getNextData()) { @@ -469,17 +511,24 @@ U32 LLScriptExecute::run(BOOL b_print, const LLUUID &id, char **errorstr, BOOL & data++; } // now, push any additional stack space - S32 additional_size = get_event_stack_size(mBuffer, current_state, event) - size; - lscript_pusharge(mBuffer, additional_size); - - // now set the bp correctly - sp = get_register(mBuffer, LREG_SP); - sp += additional_size + size; - set_bp(mBuffer, sp); - // set IP to the function - S32 opcode_start = get_state_event_opcoode_start(mBuffer, current_state, event); - set_ip(mBuffer, opcode_start); - mEventData.mEventDataList.deleteCurrentData(); + S32 additional_size = get_event_stack_size(mBuffer, current_state, event); + if ( additional_size == -1 ) + { // b_done will be set, so we'll exit the loop at the bottom + recordBoundaryError( id ); + } + else + { + additional_size -= size; + lscript_pusharge(mBuffer, additional_size); + + // now set the bp correctly + sp = get_register(mBuffer, LREG_SP); + sp += additional_size + size; + set_bp(mBuffer, sp); + // set IP to the function + setStateEventOpcoodeStartSafely( current_state, event, id ); + mEventData.mEventDataList.deleteCurrentData(); + } b_done = TRUE; break; } @@ -516,16 +565,23 @@ U32 LLScriptExecute::run(BOOL b_print, const LLUUID &id, char **errorstr, BOOL & } b_done = TRUE; // now, push any additional stack space - S32 additional_size = get_event_stack_size(mBuffer, current_state, event) - size; - lscript_pusharge(mBuffer, additional_size); - - // now set the bp correctly - sp = get_register(mBuffer, LREG_SP); - sp += additional_size + size; - set_bp(mBuffer, sp); - // set IP to the function - S32 opcode_start = get_state_event_opcoode_start(mBuffer, current_state, event); - set_ip(mBuffer, opcode_start); + S32 additional_size = get_event_stack_size(mBuffer, current_state, event); + if ( additional_size == -1 ) + { // b_done was just set, so we'll exit the loop at the bottom + recordBoundaryError( id ); + } + else + { + additional_size -= size; + lscript_pusharge(mBuffer, additional_size); + + // now set the bp correctly + sp = get_register(mBuffer, LREG_SP); + sp += additional_size + size; + set_bp(mBuffer, sp); + // set IP to the function + setStateEventOpcoodeStartSafely( current_state, event, id ); + } } else { @@ -550,23 +606,30 @@ U32 LLScriptExecute::run(BOOL b_print, const LLUUID &id, char **errorstr, BOOL & current_events &= ~LSCRIPTStateBitField[event]; set_event_register(mBuffer, LREG_CE, current_events, major_version); // now, push any additional stack space - S32 additional_size = get_event_stack_size(mBuffer, current_state, event) - size; - lscript_pusharge(mBuffer, additional_size); - - // now set the bp correctly - sp = get_register(mBuffer, LREG_SP); - sp += additional_size + size; - set_bp(mBuffer, sp); - // set IP to the function - S32 opcode_start = get_state_event_opcoode_start(mBuffer, current_state, event); - set_ip(mBuffer, opcode_start); + S32 additional_size = get_event_stack_size(mBuffer, current_state, event); + if ( additional_size == -1 ) + { // b_done will be set, so we'll exit the loop at the bottom + recordBoundaryError( id ); + } + else + { + additional_size -= size; + lscript_pusharge(mBuffer, additional_size); + + // now set the bp correctly + sp = get_register(mBuffer, LREG_SP); + sp += additional_size + size; + set_bp(mBuffer, sp); + // set IP to the function + setStateEventOpcoodeStartSafely( current_state, event, id ); + } } b_done = TRUE; } - } + } // while (!b_done) + } // end of else ... in state processing code - return NO_DELETE_FLAG; - } + return NO_DELETE_FLAG; } BOOL run_noop(U8 *buffer, S32 &offset, BOOL b_print, const LLUUID &id) diff --git a/linden/indra/lscript/lscript_execute/lscript_heapruntime.cpp b/linden/indra/lscript/lscript_execute/lscript_heapruntime.cpp index 073a736..057db79 100644 --- a/linden/indra/lscript/lscript_execute/lscript_heapruntime.cpp +++ b/linden/indra/lscript/lscript_execute/lscript_heapruntime.cpp @@ -2,6 +2,8 @@ * @file lscript_heapruntime.cpp * @brief classes to manage script heap at runtime * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #if 0 diff --git a/linden/indra/lscript/lscript_execute/lscript_heapruntime.h b/linden/indra/lscript/lscript_execute/lscript_heapruntime.h index 8431ea5..c4ade6c 100644 --- a/linden/indra/lscript/lscript_execute/lscript_heapruntime.h +++ b/linden/indra/lscript/lscript_execute/lscript_heapruntime.h @@ -2,6 +2,8 @@ * @file lscript_heapruntime.h * @brief classes to manage script heap at runtime * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #if 0 diff --git a/linden/indra/lscript/lscript_execute/lscript_readlso.cpp b/linden/indra/lscript/lscript_execute/lscript_readlso.cpp index f84abc5..8ecd8cd 100644 --- a/linden/indra/lscript/lscript_execute/lscript_readlso.cpp +++ b/linden/indra/lscript/lscript_execute/lscript_readlso.cpp @@ -2,6 +2,8 @@ * @file lscript_readlso.cpp * @brief classes to read lso file * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" diff --git a/linden/indra/lscript/lscript_execute/lscript_readlso.h b/linden/indra/lscript/lscript_execute/lscript_readlso.h index 8fa5211..92c9dfa 100644 --- a/linden/indra/lscript/lscript_execute/lscript_readlso.h +++ b/linden/indra/lscript/lscript_execute/lscript_readlso.h @@ -2,6 +2,8 @@ * @file lscript_readlso.h * @brief classes to read lso file * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LSCRIPT_READLSO_H diff --git a/linden/indra/lscript/lscript_export.h b/linden/indra/lscript/lscript_export.h index d9f7f18..0384569 100644 --- a/linden/indra/lscript/lscript_export.h +++ b/linden/indra/lscript/lscript_export.h @@ -2,6 +2,8 @@ * @file lscript_export.h * @brief Export interface class * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LSCRIPT_EXPORT_H diff --git a/linden/indra/lscript/lscript_http.h b/linden/indra/lscript/lscript_http.h index c562093..cb60090 100644 --- a/linden/indra/lscript/lscript_http.h +++ b/linden/indra/lscript/lscript_http.h @@ -2,6 +2,8 @@ * @file lscript_http.h * @brief LSL HTTP keys * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Keys used in LSL HTTP function pair lists. diff --git a/linden/indra/lscript/lscript_library.h b/linden/indra/lscript/lscript_library.h index 353ff69..a15805f 100644 --- a/linden/indra/lscript/lscript_library.h +++ b/linden/indra/lscript/lscript_library.h @@ -2,6 +2,8 @@ * @file lscript_library.h * @brief External library interface * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LSCRIPT_LIBRARY_H @@ -34,7 +37,6 @@ #include "llquaternion.h" #include "lluuid.h" #include "lscript_byteconvert.h" -#include class LLScriptLibData; diff --git a/linden/indra/lscript/lscript_library/lscript_alloc.cpp b/linden/indra/lscript/lscript_library/lscript_alloc.cpp index 99e6917..a2f83e7 100644 --- a/linden/indra/lscript/lscript_library/lscript_alloc.cpp +++ b/linden/indra/lscript/lscript_library/lscript_alloc.cpp @@ -2,6 +2,8 @@ * @file lscript_alloc.cpp * @brief general heap management for scripting system * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // #define at top of file accelerates gcc compiles @@ -31,8 +34,8 @@ // Under gcc 3, the manual explicitly states comments can appear above the #ifndef #include "linden_common.h" - #include "lscript_alloc.h" +#include "llrand.h" // supported data types diff --git a/linden/indra/lscript/lscript_library/lscript_export.cpp b/linden/indra/lscript/lscript_library/lscript_export.cpp index be95d30..26d1361 100644 --- a/linden/indra/lscript/lscript_library/lscript_export.cpp +++ b/linden/indra/lscript/lscript_library/lscript_export.cpp @@ -2,6 +2,8 @@ * @file lscript_export.cpp * @brief export interface class * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,5 +26,6 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ diff --git a/linden/indra/lscript/lscript_library/lscript_library.cpp b/linden/indra/lscript/lscript_library/lscript_library.cpp index 3f939c4..e082220 100644 --- a/linden/indra/lscript/lscript_library/lscript_library.cpp +++ b/linden/indra/lscript/lscript_library/lscript_library.cpp @@ -2,6 +2,8 @@ * @file lscript_library.cpp * @brief external library interface * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // *WARNING* diff --git a/linden/indra/lscript/lscript_rt_interface.h b/linden/indra/lscript/lscript_rt_interface.h index f595cbe..791c447 100644 --- a/linden/indra/lscript/lscript_rt_interface.h +++ b/linden/indra/lscript/lscript_rt_interface.h @@ -2,6 +2,8 @@ * @file lscript_rt_interface.h * @brief Interface between compiler library and applications * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LSCRIPT_RT_INTERFACE_H diff --git a/linden/indra/mac_crash_logger/mac_crash_logger.cpp b/linden/indra/mac_crash_logger/mac_crash_logger.cpp index b1f70e0..2501b4a 100644 --- a/linden/indra/mac_crash_logger/mac_crash_logger.cpp +++ b/linden/indra/mac_crash_logger/mac_crash_logger.cpp @@ -2,6 +2,8 @@ * @file mac_crash_logger.cpp * @brief Mac OSX crash logger implementation * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,14 +26,11 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" -#include -#include -//#include -#include #include #include #include diff --git a/linden/indra/mac_updater/FSCopyObject.h b/linden/indra/mac_updater/FSCopyObject.h index c39b2d9..b21155c 100644 --- a/linden/indra/mac_updater/FSCopyObject.h +++ b/linden/indra/mac_updater/FSCopyObject.h @@ -2,6 +2,8 @@ * @file FSCopyObject.h * @brief Mac OSX updater program * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /* diff --git a/linden/indra/mac_updater/GenLinkedList.h b/linden/indra/mac_updater/GenLinkedList.h index 23f2165..709da5f 100644 --- a/linden/indra/mac_updater/GenLinkedList.h +++ b/linden/indra/mac_updater/GenLinkedList.h @@ -2,6 +2,8 @@ * @file GenLinkedList.h * @brief Mac OSX updater program * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /* diff --git a/linden/indra/mac_updater/MoreFilesX.h b/linden/indra/mac_updater/MoreFilesX.h index 6e4718f..1dcfe2b 100644 --- a/linden/indra/mac_updater/MoreFilesX.h +++ b/linden/indra/mac_updater/MoreFilesX.h @@ -2,6 +2,8 @@ * @file MoreFilesX.h * @brief Mac OS X updater program * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /* diff --git a/linden/indra/mac_updater/mac_updater.cpp b/linden/indra/mac_updater/mac_updater.cpp index 659fbf4a..d5e806f 100644 --- a/linden/indra/mac_updater/mac_updater.cpp +++ b/linden/indra/mac_updater/mac_updater.cpp @@ -2,6 +2,8 @@ * @file mac_updater.cpp * @brief * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,14 +26,11 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "linden_common.h" -#include -#include -//#include -#include #include #include #include diff --git a/linden/indra/newview/English.lproj/InfoPlist.strings b/linden/indra/newview/English.lproj/InfoPlist.strings index 420236c..d01c217 100644 --- a/linden/indra/newview/English.lproj/InfoPlist.strings +++ b/linden/indra/newview/English.lproj/InfoPlist.strings @@ -1,5 +1,5 @@ /* Localized versions of Info.plist keys */ CFBundleName = "Second Life"; -CFBundleShortVersionString = "Second Life version 1.18.3.5"; -CFBundleGetInfoString = "Second Life version 1.18.3.5, Copyright 2004-2007 Linden Research, Inc."; +CFBundleShortVersionString = "Second Life version 1.18.4.0"; +CFBundleGetInfoString = "Second Life version 1.18.4.0, Copyright 2004-2007 Linden Research, Inc."; diff --git a/linden/indra/newview/Info-SecondLife.plist b/linden/indra/newview/Info-SecondLife.plist index 263babe..e6c366f 100644 --- a/linden/indra/newview/Info-SecondLife.plist +++ b/linden/indra/newview/Info-SecondLife.plist @@ -32,7 +32,7 @@ CFBundleVersion - 1.18.3.5 + 1.18.4.0 CSResourcesFileMapped diff --git a/linden/indra/newview/VertexCache.h b/linden/indra/newview/VertexCache.h index 76ad3cc..e1591c7 100644 --- a/linden/indra/newview/VertexCache.h +++ b/linden/indra/newview/VertexCache.h @@ -2,6 +2,8 @@ * @file VertexCache.h * @brief VertexCache class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ diff --git a/linden/indra/newview/VorbisFramework.h b/linden/indra/newview/VorbisFramework.h index 6af4a14..48dabb9 100644 --- a/linden/indra/newview/VorbisFramework.h +++ b/linden/indra/newview/VorbisFramework.h @@ -4,6 +4,8 @@ * @date Fri Oct 10 2003 * @brief For the Macview project * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifdef __cplusplus diff --git a/linden/indra/newview/audiosettings.h b/linden/indra/newview/audiosettings.h index 714d02a..344fbc0 100644 --- a/linden/indra/newview/audiosettings.h +++ b/linden/indra/newview/audiosettings.h @@ -2,6 +2,8 @@ * @file audiosettings.h * @brief AudioSettings definitions * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_AUDIOSETTINGS_H diff --git a/linden/indra/newview/fakevoicesoundsignal.cpp b/linden/indra/newview/fakevoicesoundsignal.cpp index 0cb5c11..7566fbd 100644 --- a/linden/indra/newview/fakevoicesoundsignal.cpp +++ b/linden/indra/newview/fakevoicesoundsignal.cpp @@ -4,6 +4,8 @@ * author: JJ Ventrella * THIS IS A TEMPORARY FILE FOR DEVELOPMENT PURPOSES ONLY * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/fakevoicesoundsignal.h b/linden/indra/newview/fakevoicesoundsignal.h index a10d9fe..40666d8 100644 --- a/linden/indra/newview/fakevoicesoundsignal.h +++ b/linden/indra/newview/fakevoicesoundsignal.h @@ -4,6 +4,8 @@ * author: JJ Ventrella * THIS IS A TEMPORARY FILE FOR DEVELOPMENT PURPOSES ONLY * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef FAKE_VOICE_SOUND_SIGNAL_H #define FAKE_VOICE_SOUND_SIGNAL_H diff --git a/linden/indra/newview/files.lst b/linden/indra/newview/files.lst index 52372b3..979ad7a 100644 --- a/linden/indra/newview/files.lst +++ b/linden/indra/newview/files.lst @@ -4,7 +4,6 @@ newview/llagentdata.cpp newview/llagentpilot.cpp newview/llanimalcontrols.cpp newview/llassetuploadresponders.cpp -newview/llasynchostbyname.cpp newview/llaudiosourcevo.cpp newview/llbbox.cpp newview/llbox.cpp @@ -18,6 +17,7 @@ newview/llclassifiedinfo.cpp newview/llcloud.cpp newview/llcolorscheme.cpp newview/llcolorswatch.cpp +newview/llcommandhandler.cpp newview/llcompass.cpp newview/llcompilequeue.cpp newview/llconfirmationmanager.cpp @@ -81,11 +81,11 @@ newview/llfloatergroupinfo.cpp newview/llfloatergroupinvite.cpp newview/llfloatergroups.cpp newview/llfloaterhtml.cpp -newview/llfloaterhtmlfind.cpp newview/llfloaterhtmlhelp.cpp newview/llfloaterimagepreview.cpp newview/llfloaterimport.cpp newview/llfloaterinspect.cpp +newview/llfloaterlagmeter.cpp newview/llfloaterland.cpp newview/llfloaterlandholdings.cpp newview/llfloatermap.cpp @@ -264,6 +264,8 @@ newview/lltoolview.cpp newview/lltracker.cpp newview/lluploaddialog.cpp newview/llurl.cpp +newview/llurldispatcher.cpp +newview/llurlsimstring.cpp newview/llurlwhitelist.cpp newview/lluserauth.cpp newview/llvelocitybar.cpp diff --git a/linden/indra/newview/fmodwrapper.cpp b/linden/indra/newview/fmodwrapper.cpp index b6f1dc7..7043959 100644 --- a/linden/indra/newview/fmodwrapper.cpp +++ b/linden/indra/newview/fmodwrapper.cpp @@ -2,6 +2,8 @@ * @file fmodwrapper.cpp * @brief dummy source file for building a shared library to wrap libfmod.a * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ extern "C" diff --git a/linden/indra/newview/head.cpp b/linden/indra/newview/head.cpp index 5bec318..c30636c 100644 --- a/linden/indra/newview/head.cpp +++ b/linden/indra/newview/head.cpp @@ -2,6 +2,8 @@ * @file head.cpp * @brief Head class implementation * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // implementation of a class that models the motion of a human head. diff --git a/linden/indra/newview/head.h b/linden/indra/newview/head.h index 234f718..d963837 100644 --- a/linden/indra/newview/head.h +++ b/linden/indra/newview/head.h @@ -2,6 +2,8 @@ * @file head.h * @brief Head class definition * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // description of a class that models the motion of a human head. @@ -32,8 +35,6 @@ #ifndef LL_HEAD_H #define LL_HEAD_H -//#include - class Head { public: diff --git a/linden/indra/newview/linux_tools/client-readme.txt b/linden/indra/newview/linux_tools/client-readme.txt index 59ebf67..641705d 100644 --- a/linden/indra/newview/linux_tools/client-readme.txt +++ b/linden/indra/newview/linux_tools/client-readme.txt @@ -99,8 +99,6 @@ the Alpha release of the Linux client. * VOICE COMMUNICATION - this is not yet available in the Linux client. -* STREAMING MOVIES - these are currently disabled while we work on some issues. - * VISUAL EFFECTS AND PERFORMANCE - many Linux graphics drivers are not as robust as their counterparts for other operating systems, so some advanced Second Life graphical features have been DISABLED by default to aid diff --git a/linden/indra/newview/linux_tools/exposed-symbols.txt b/linden/indra/newview/linux_tools/exposed-symbols.txt index 98df90a..f12fbfa 100644 --- a/linden/indra/newview/linux_tools/exposed-symbols.txt +++ b/linden/indra/newview/linux_tools/exposed-symbols.txt @@ -1,3 +1,4 @@ initllpython createLLImageJ2CKDU destroyLLImageJ2CKDU +engineInfoLLImageJ2CKDU diff --git a/linden/indra/newview/linux_tools/launch_url.sh b/linden/indra/newview/linux_tools/launch_url.sh index a1c6f5d..e6450ad 100755 --- a/linden/indra/newview/linux_tools/launch_url.sh +++ b/linden/indra/newview/linux_tools/launch_url.sh @@ -1,5 +1,4 @@ -#!/bin/sh -# Script tested with: bash 1.14, bash 3.1.17, zsh 4.2.5, ksh 1993-12-28 +#!/bin/bash # This script loads a web page in the 'default' graphical web browser. # It MUST return immediately (or soon), so the browser should be diff --git a/linden/indra/newview/linux_tools/wrapper.sh b/linden/indra/newview/linux_tools/wrapper.sh index fd15f21..10041ee 100755 --- a/linden/indra/newview/linux_tools/wrapper.sh +++ b/linden/indra/newview/linux_tools/wrapper.sh @@ -1,5 +1,4 @@ -#!/bin/sh -# Script tested with: bash 1.14, bash 3.1.17, zsh 4.2.5, ksh 1993-12-28 +#!/bin/bash ## Here are some configuration options for Linux Client Alpha Testers. ## These options are for self-assisted troubleshooting during this alpha @@ -33,6 +32,10 @@ export LL_GL_BASICEXT=x ## LL_GL_BLACKLIST which solves your problems. #export LL_GL_BLACKLIST=abcdefghijklmno + +## Everything below this line is just for advanced troubleshooters. +##------------------------------------------------------------------- + ## - For advanced debugging cases, you can run the viewer under the ## control of another program, such as strace, gdb, or valgrind. If ## you're building your own viewer, bear in mind that the executable @@ -47,6 +50,12 @@ export SDL_VIDEO_X11_DGAMOUSE=0 ## - Works around a problem with misconfigured 64-bit systems not finding GL export LIBGL_DRIVERS_PATH="${LIBGL_DRIVERS_PATH}":/usr/lib64/dri:/usr/lib32/dri:/usr/lib/dri +## - The 'scim' GTK IM module widely crashes the viewer. Avoid it. +if [ "$GTK_IM_MODULE" = "scim" ]; then + export GTK_IM_MODULE=xim +fi + + ## Nothing worth editing below this line. ##------------------------------------------------------------------- @@ -74,7 +83,30 @@ export SL_ENV='LD_LIBRARY_PATH="`pwd`"/lib:"`pwd`"/app_settings/mozilla-runtime- export SL_CMD='$LL_WRAPPER bin/do-not-directly-run-secondlife-bin' export SL_OPT="`cat gridargs.dat` $@" -eval ${SL_ENV} ${SL_CMD} ${SL_OPT} || echo Unclean shutdown. +# Run the program +eval ${SL_ENV} ${SL_CMD} ${SL_OPT} || LL_RUN_ERR=runerr + +# Handle any resulting errors +if [ -n "$LL_RUN_ERR" ]; then + LL_RUN_ERR_MSG="" + if [ "$LL_RUN_ERR" = "runerr" ]; then + # generic error running the binary + echo '*** Unclean shutdown. ***' + if [ "`arch`" = "x86_64" ]; then + echo + cat << EOFMARKER +You are running the Second Life Viewer on a x86_64 platform. The +most common problems when launching the Viewer (particularly +'bin/do-not-directly-run-secondlife-bin: not found' and 'error while +loading shared libraries') may be solved by installing your Linux +distribution's 32-bit compatibility packages. +For example, on Ubuntu and other Debian-based Linuxes you might run: +$ sudo apt-get install ia32-libs ia32-libs-gtk ia32-libs-kde ia32-libs-sdl +EOFMARKER + fi + fi +fi + echo echo '*********************************************************' diff --git a/linden/indra/newview/llagent.cpp b/linden/indra/newview/llagent.cpp index bf54472..d825704 100644 --- a/linden/indra/newview/llagent.cpp +++ b/linden/indra/newview/llagent.cpp @@ -2,6 +2,8 @@ * @file llagent.cpp * @brief LLAgent class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -48,6 +51,7 @@ #include "llquaternion.h" #include "v3math.h" #include "v4math.h" +#include "llsdutil.h" //#include "vmath.h" #include "imageids.h" @@ -1857,7 +1861,7 @@ void LLAgent::cameraOrbitIn(const F32 meters) if (new_distance > max_distance) { // Unless camera is unlocked - if (!LLViewerCamera::sDisableCameraConstraints) + if (!gSavedSettings.getBOOL("DisableCameraConstraints")) { return; } @@ -2034,7 +2038,8 @@ void LLAgent::setAFK() gAwayTimer.start(); if (gAFKMenu) { - gAFKMenu->setLabel("Set Not Away"); + //*TODO:Translate + gAFKMenu->setLabel(LLString("Set Not Away")); } } } @@ -2057,7 +2062,8 @@ void LLAgent::clearAFK() clearControlFlags(AGENT_CONTROL_AWAY); if (gAFKMenu) { - gAFKMenu->setLabel("Set Away"); + //*TODO:Translate + gAFKMenu->setLabel(LLString("Set Away")); } } } @@ -2079,7 +2085,8 @@ void LLAgent::setBusy() mIsBusy = TRUE; if (gBusyMenu) { - gBusyMenu->setLabel("Set Not Busy"); + //*TODO:Translate + gBusyMenu->setLabel(LLString("Set Not Busy")); } if (gFloaterMute) { @@ -2096,7 +2103,8 @@ void LLAgent::clearBusy() sendAnimationRequest(ANIM_AGENT_BUSY, ANIM_REQUEST_STOP); if (gBusyMenu) { - gBusyMenu->setLabel("Set Busy"); + //*TODO:Translate + gBusyMenu->setLabel(LLString("Set Busy")); } if (gFloaterMute) { @@ -3773,7 +3781,7 @@ LLVector3d LLAgent::calcCameraPositionTargetGlobal(BOOL *hit_limit) camera_position_global = focusPosGlobal + mCameraFocusOffset; } - if (!LLViewerCamera::sDisableCameraConstraints && !gAgent.isGodlike()) + if (!gSavedSettings.getBOOL("DisableCameraConstraints") && !gAgent.isGodlike()) { LLViewerRegion* regionp = gWorldPointer->getRegionFromPosGlobal( camera_position_global); @@ -3897,7 +3905,7 @@ F32 LLAgent::getCameraMinOffGround() } else { - if (LLViewerCamera::sDisableCameraConstraints) + if (gSavedSettings.getBOOL("DisableCameraConstraints")) { return -1000.f; } @@ -4828,7 +4836,7 @@ BOOL LLAgent::setGroupContribution(const LLUUID& group_id, S32 contribution) return FALSE; } -BOOL LLAgent::setGroupAcceptNotices(const LLUUID& group_id, BOOL accept_notices) +BOOL LLAgent::setUserGroupFlags(const LLUUID& group_id, BOOL accept_notices, BOOL list_in_profile) { S32 count = mGroups.count(); for(S32 i = 0; i < count; ++i) @@ -4836,6 +4844,7 @@ BOOL LLAgent::setGroupAcceptNotices(const LLUUID& group_id, BOOL accept_notices) if(mGroups.get(i).mID == group_id) { mGroups.get(i).mAcceptNotices = accept_notices; + mGroups.get(i).mListInProfile = list_in_profile; LLMessageSystem* msg = gMessageSystem; msg->newMessage("SetGroupAcceptNotices"); msg->nextBlock("AgentData"); @@ -4844,6 +4853,8 @@ BOOL LLAgent::setGroupAcceptNotices(const LLUUID& group_id, BOOL accept_notices) msg->nextBlock("Data"); msg->addUUID("GroupID", group_id); msg->addBOOL("AcceptNotices", accept_notices); + msg->nextBlock("NewData"); + msg->addBOOL("ListInProfile", list_in_profile); sendReliableMessage(); return TRUE; } @@ -4881,7 +4892,7 @@ void LLAgent::buildLocationString(std::string& str) // create a defult name and description for the landmark std::string buffer; - if( !strcmp("", gParcelMgr->getAgentParcelName()) ) + if( gParcelMgr->getAgentParcelName().empty() ) { // the parcel doesn't have a name buffer = llformat("%.32s (%d, %d, %d)", @@ -4892,7 +4903,7 @@ void LLAgent::buildLocationString(std::string& str) { // the parcel has a name, so include it in the landmark name buffer = llformat("%.32s, %.32s (%d, %d, %d)", - gParcelMgr->getAgentParcelName(), + gParcelMgr->getAgentParcelName().c_str(), getRegion()->getName().c_str(), pos_x, pos_y, pos_z); } @@ -5197,6 +5208,70 @@ void LLAgent::processAgentGroupDataUpdate(LLMessageSystem *msg, void **) } +class LLAgentGroupDataUpdateViewerNode : public LLHTTPNode +{ + virtual void post( + LLHTTPNode::ResponsePtr response, + const LLSD& context, + const LLSD& input) const + { + LLSD body = input["body"]; + if(body.has("body")) + body = body["body"]; + LLUUID agent_id = body["AgentData"][0]["AgentID"].asUUID(); + + if (agent_id != gAgentID) + { + llwarns << "processAgentGroupDataUpdate for agent other than me" << llendl; + return; + } + + LLSD group_data = body["GroupData"]; + + LLSD::array_iterator iter_group = + group_data.beginArray(); + LLSD::array_iterator end_group = + group_data.endArray(); + int group_index = 0; + for(; iter_group != end_group; ++iter_group) + { + + LLGroupData group; + S32 index = -1; + bool need_floater_update = false; + + group.mID = (*iter_group)["GroupID"].asUUID(); + group.mPowers = ll_U64_from_sd((*iter_group)["GroupPowers"]); + group.mAcceptNotices = (*iter_group)["AcceptNotices"].asBoolean(); + group.mListInProfile = body["NewGroupData"][group_index]["ListInProfile"].asBoolean(); + group.mInsigniaID = (*iter_group)["GroupInsigniaID"].asUUID(); + group.mName = (*iter_group)["GroupName"].asString(); + group.mContribution = (*iter_group)["Contribution"].asInteger(); + + group_index++; + + if(group.mID.notNull()) + { + need_floater_update = true; + // Remove the group if it already exists remove it and add the new data to pick up changes. + index = gAgent.mGroups.find(group); + if (index != -1) + { + gAgent.mGroups.remove(index); + } + gAgent.mGroups.put(group); + } + if (need_floater_update) + { + update_group_floaters(group.mID); + } + } + } +}; + +LLHTTPRegistration + gHTTPRegistrationAgentGroupDataUpdateViewerNode ("/message/AgentGroupDataUpdate"); + // static void LLAgent::processAgentDataUpdate(LLMessageSystem *msg, void **) { @@ -7289,5 +7364,4 @@ void LLAgent::parseTeleportMessages(const LLString& xml_filename) }//end for (all message sets in xml file) } - // EOF diff --git a/linden/indra/newview/llagent.h b/linden/indra/newview/llagent.h index 9c53fe1..5b6c3c0 100644 --- a/linden/indra/newview/llagent.h +++ b/linden/indra/newview/llagent.h @@ -2,6 +2,8 @@ * @file llagent.h * @brief LLAgent class header file * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLAGENT_H @@ -98,6 +101,7 @@ struct LLGroupData LLUUID mInsigniaID; U64 mPowers; BOOL mAcceptNotices; + BOOL mListInProfile; S32 mContribution; std::string mName; }; @@ -217,7 +221,7 @@ public: // new contribution level. Returns true if the group id was found // and contribution could be set. BOOL setGroupContribution(const LLUUID& group_id, S32 contribution); - BOOL setGroupAcceptNotices(const LLUUID& group_id, BOOL accept_notices); + BOOL setUserGroupFlags(const LLUUID& group_id, BOOL accept_notices, BOOL list_in_profile); void setHideGroupTitle(BOOL hide) { mHideGroupTitle = hide; } // @@ -418,7 +422,7 @@ public: void propagate(const F32 dt); // BUG: should roll into updateAgentPosition - void startAutoPilotGlobal(const LLVector3d &pos_global, const std::string& behavior_name = "", const LLQuaternion *target_rotation = NULL, + void startAutoPilotGlobal(const LLVector3d &pos_global, const std::string& behavior_name = std::string(), const LLQuaternion *target_rotation = NULL, void (*finish_callback)(BOOL, void *) = NULL, void *callback_data = NULL, F32 stop_distance = 0.f, F32 rotation_threshold = 0.03f); void startFollowPilot(const LLUUID &leader_id); diff --git a/linden/indra/newview/llagentdata.cpp b/linden/indra/newview/llagentdata.cpp index 464a37b..155eda9 100644 --- a/linden/indra/newview/llagentdata.cpp +++ b/linden/indra/newview/llagentdata.cpp @@ -3,6 +3,8 @@ * @brief Contains commonly used agent data. * @author James Cook * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llagentdata.h b/linden/indra/newview/llagentdata.h index eba2a29..7f0e28d 100644 --- a/linden/indra/newview/llagentdata.h +++ b/linden/indra/newview/llagentdata.h @@ -3,6 +3,8 @@ * @brief Contains commonly used agent data * @author James Cook * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLAGENTDATA_H diff --git a/linden/indra/newview/llagentpilot.cpp b/linden/indra/newview/llagentpilot.cpp index 0ccfd45..9637c54 100644 --- a/linden/indra/newview/llagentpilot.cpp +++ b/linden/indra/newview/llagentpilot.cpp @@ -2,6 +2,8 @@ * @file llagentpilot.cpp * @brief LLAgentPilot class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llagentpilot.h b/linden/indra/newview/llagentpilot.h index 9f1a3c9..3a3140a 100644 --- a/linden/indra/newview/llagentpilot.h +++ b/linden/indra/newview/llagentpilot.h @@ -2,6 +2,8 @@ * @file llagentpilot.h * @brief LLAgentPilot class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLAGENTPILOT_H diff --git a/linden/indra/newview/llanimalcontrols.cpp b/linden/indra/newview/llanimalcontrols.cpp index da3c6e8..e08864c 100644 --- a/linden/indra/newview/llanimalcontrols.cpp +++ b/linden/indra/newview/llanimalcontrols.cpp @@ -2,6 +2,8 @@ * @file llanimalcontrols.cpp * @brief LLAnimalControl class implementation * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llanimalcontrols.h b/linden/indra/newview/llanimalcontrols.h index 73e8679..36a1bca 100644 --- a/linden/indra/newview/llanimalcontrols.h +++ b/linden/indra/newview/llanimalcontrols.h @@ -2,6 +2,8 @@ * @file llanimalcontrols.h * @brief LLAnimalControls class definition * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLANIMALCONTROLS_H diff --git a/linden/indra/newview/llappearance.h b/linden/indra/newview/llappearance.h index 2a6a95e..2a4c175 100644 --- a/linden/indra/newview/llappearance.h +++ b/linden/indra/newview/llappearance.h @@ -2,6 +2,8 @@ * @file llappearance.h * @brief LLAppearance class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLAPPEARANCE_H diff --git a/linden/indra/newview/llassetuploadresponders.cpp b/linden/indra/newview/llassetuploadresponders.cpp index efe71e1..866fa34 100644 --- a/linden/indra/newview/llassetuploadresponders.cpp +++ b/linden/indra/newview/llassetuploadresponders.cpp @@ -2,7 +2,9 @@ * @file llassetuploadresponders.cpp * @brief Processes responses received for asset upload requests. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -41,6 +44,8 @@ #include "llpermissionsflags.h" #include "llpreviewnotecard.h" #include "llpreviewscript.h" +#include "llpreviewgesture.h" +#include "llgesturemgr.h" #include "llscrolllistctrl.h" #include "lluploaddialog.h" #include "llviewerobject.h" @@ -381,6 +386,27 @@ void LLUpdateAgentInventoryResponder::uploadComplete(const LLSD& content) } } break; + + case LLInventoryType::IT_GESTURE: + { + // If this gesture is active, then we need to update the in-memory + // active map with the new pointer. + if (gGestureManager.isGestureActive(item_id)) + { + LLUUID asset_id = new_item->getAssetUUID(); + gGestureManager.replaceGesture(item_id, asset_id); + gInventory.notifyObservers(); + } + + //gesture will have a new asset_id + LLPreviewGesture* previewp = (LLPreviewGesture*)LLPreview::find(item_id); + if(previewp) + { + previewp->onUpdateSucceeded(); + } + + } + break; case LLInventoryType::IT_WEARABLE: default: break; diff --git a/linden/indra/newview/llassetuploadresponders.h b/linden/indra/newview/llassetuploadresponders.h index 4744d34..25f3f4c 100644 --- a/linden/indra/newview/llassetuploadresponders.h +++ b/linden/indra/newview/llassetuploadresponders.h @@ -2,7 +2,9 @@ * @file llassetuploadresponders.h * @brief Processes responses received for asset upload requests. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLASSETUPLOADRESPONDER_H diff --git a/linden/indra/newview/llasynchostbyname.cpp b/linden/indra/newview/llasynchostbyname.cpp deleted file mode 100644 index 8eebe8b..0000000 --- a/linden/indra/newview/llasynchostbyname.cpp +++ /dev/null @@ -1,229 +0,0 @@ -/** - * @file llasynchostbyname.cpp - * @brief Wrapper for Windows asychronous DNS lookup functionality - * - * Copyright (c) 2003-2007, Linden Research, Inc. - * - * Second Life Viewer Source Code - * The source code in this file ("Source Code") is provided by Linden Lab - * to you under the terms of the GNU General Public License, version 2.0 - * ("GPL"), unless you have obtained a separate licensing agreement - * ("Other License"), formally executed by you and Linden Lab. Terms of - * the GPL can be found in doc/GPL-license.txt in this distribution, or - * online at http://secondlife.com/developers/opensource/gplv2 - * - * There are special exceptions to the terms and conditions of the GPL as - * it is applied to this Source Code. View the full text of the exception - * in the file doc/FLOSS-exception.txt in this software distribution, or - * online at http://secondlife.com/developers/opensource/flossexception - * - * By copying, modifying or distributing this software, you acknowledge - * that you have read and understood your obligations described above, - * and agree to abide by those obligations. - * - * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO - * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, - * COMPLETENESS OR PERFORMANCE. - */ - -// standard LL includes -#include "llviewerprecompiledheaders.h" - -// self include -#include "llasynchostbyname.h" - -// -// Globals -// -LLAsyncHostByName gAsyncHostByName; - - -// -// Parallel implementations for Windows/UNIX! -// -#if LL_WINDOWS - -#include "llviewerwindow.h" -// Place to register the Windows callback -extern void (*gAsyncMsgCallback)(const MSG &msg); - - -// member functions -LLAsyncHostByName::LLAsyncHostByName() - : - mRequestHandle(0), - mCallback(NULL), - mUserdata(NULL) -{ - gAsyncMsgCallback = LLAsyncHostByName::handleMessageCallback; - memset(mOutputBuffer, 0, sizeof( mOutputBuffer ) ); -} - - -LLAsyncHostByName::~LLAsyncHostByName() -{ -} - - -BOOL LLAsyncHostByName::startRequest( const LLString& domain_name, LLAsyncHostByNameCallback callback, void* userdata ) -{ - if( isPendingRequest() ) - { - llwarns << "LLAsyncHostByName::startRequest() cancelled existing request." << llendl; - cancelPendingRequest(); - } - - mCallback = callback; - mUserdata = userdata; - memset(mOutputBuffer, 0, sizeof( mOutputBuffer ) ); - mDomainName = domain_name; - - mRequestHandle = WSAAsyncGetHostByName( - (HWND)gViewerWindow->getPlatformWindow(), - LL_WM_HOST_RESOLVED, - domain_name.c_str(), - mOutputBuffer, - sizeof( mOutputBuffer ) ); - - if( !mRequestHandle ) - { - llwarns << "LLAsyncHostByName::startRequest() failed: " << WSAGetLastError() << llendl; - return FALSE; - } - - return TRUE; -} - - -void LLAsyncHostByName::handleMessage( const MSG& msg ) -{ - if( (HANDLE)msg.wParam != mRequestHandle ) - { - llwarns << "LL_WM_HOST_RESOLVED received for request we weren't waiting for. Ignored." << llendl; - return; - } - llinfos << "LL_WM_HOST_RESOLVED" << llendl; - - BOOL success = FALSE; - U32 ip = 0; - S32 error = WSAGETASYNCERROR( msg.lParam ); - if( error ) - { - if( error == WSANO_DATA) - { - llwarns << "Unknown host" << llendl; - } - else - { - llwarns << "Resolve host error" << WSAGetLastError () << llendl; - } - } - else - { - HOSTENT* he = (HOSTENT*) mOutputBuffer; - char** addr_list = he->h_addr_list; - if (!addr_list) - { - llwarns << "Bad HOSTENT in LLAsyncHostByName" << llendl; - return; - } - char* first_addr = addr_list[0]; - if (!first_addr) - { - llwarns << "Bad address in HOSTENT in LLAsyncHostByName" << llendl; - return; - } - ip = *(U32*)first_addr; - success = TRUE; - } - - if( mCallback ) - { - mCallback( success, mDomainName, ip, mUserdata ); - } - mCallback = NULL; - mUserdata = NULL; - mRequestHandle = 0; - mDomainName.clear(); -} - - -BOOL LLAsyncHostByName::cancelPendingRequest() -{ - if( mCallback ) - { - mCallback( FALSE, mDomainName, 0, mUserdata ); - } - mUserdata = NULL; - mCallback = NULL; - - if( mRequestHandle ) - { - S32 ret = WSACancelAsyncRequest( mRequestHandle ); - if( SOCKET_ERROR == ret ) - { - llwarns << "LLAsyncHostByName::cancelPendingRequest() failed: " << WSAGetLastError() << llendl; - return FALSE; - } - memset(mOutputBuffer, 0, sizeof( mOutputBuffer ) ); - mRequestHandle = 0; - return TRUE; - } - - return FALSE; -} - - -// static -void LLAsyncHostByName::handleMessageCallback(const MSG& msg) -{ - gAsyncHostByName.handleMessage(msg); -} - - -#else // !LL_WINDOWS - - -#include -#include -#include - - -// member functions -LLAsyncHostByName::LLAsyncHostByName() -{ -} - - -LLAsyncHostByName::~LLAsyncHostByName() -{ -} - - -BOOL LLAsyncHostByName::startRequest( const LLString& domain_name, LLAsyncHostByNameCallback callback, void* userdata ) -{ - struct hostent *response; - U32 ip; - BOOL result = FALSE; - - response = gethostbyname(domain_name.c_str()); - - if(response != NULL) - { - if(response->h_addrtype == AF_INET) - { - ip = ((struct in_addr*)response->h_addr_list[0])->s_addr; - result = TRUE; - (*callback)(result, domain_name, ip, userdata); - } - } - return result; -} - - -BOOL LLAsyncHostByName::cancelPendingRequest() -{ - // Since this implementation is synchronous, there's nothing to do here. - return TRUE; -} -#endif // !LL_WINDOWS diff --git a/linden/indra/newview/llasynchostbyname.h b/linden/indra/newview/llasynchostbyname.h deleted file mode 100644 index 30dedd0..0000000 --- a/linden/indra/newview/llasynchostbyname.h +++ /dev/null @@ -1,93 +0,0 @@ -/** - * @file llasynchostbyname.h - * @brief Wrapper for Windows asychronous DNS lookup functionality - * - * Copyright (c) 2003-2007, Linden Research, Inc. - * - * Second Life Viewer Source Code - * The source code in this file ("Source Code") is provided by Linden Lab - * to you under the terms of the GNU General Public License, version 2.0 - * ("GPL"), unless you have obtained a separate licensing agreement - * ("Other License"), formally executed by you and Linden Lab. Terms of - * the GPL can be found in doc/GPL-license.txt in this distribution, or - * online at http://secondlife.com/developers/opensource/gplv2 - * - * There are special exceptions to the terms and conditions of the GPL as - * it is applied to this Source Code. View the full text of the exception - * in the file doc/FLOSS-exception.txt in this software distribution, or - * online at http://secondlife.com/developers/opensource/flossexception - * - * By copying, modifying or distributing this software, you acknowledge - * that you have read and understood your obligations described above, - * and agree to abide by those obligations. - * - * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO - * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, - * COMPLETENESS OR PERFORMANCE. - */ - -#ifndef LL_LLASYNCHOSTBYNAME_H -#define LL_LLASYNCHOSTBYNAME_H - -#if LL_WINDOWS -// -// Only implemented on Windows -// - -#define LL_WM_HOST_RESOLVED (WM_APP + 1) - -typedef void (*LLAsyncHostByNameCallback)(BOOL success, const LLString& domain_name, U32 ip, void*); - -class LLAsyncHostByName -{ -public: - LLAsyncHostByName(); - ~LLAsyncHostByName(); - - BOOL startRequest( const LLString& domain_name, LLAsyncHostByNameCallback callback, void* userdata ); - void handleMessage( const MSG& msg ); - - BOOL isPendingRequest() { return (mRequestHandle != 0); } - BOOL cancelPendingRequest(); - - static void handleMessageCallback(const MSG& msg); -private: - HANDLE mRequestHandle; - char mOutputBuffer[ MAXGETHOSTSTRUCT ]; /*Flawfinder: ignore*/ - - LLAsyncHostByNameCallback mCallback; - void* mUserdata; - LLString mDomainName; - -}; - -extern LLAsyncHostByName gAsyncHostByName; - -#else // LL_WINDOWS - -// MBW -- Replicate this object on top of the posix gethostbyname() API. -// For now, it will be synchronous. - -#include "llstring.h" - -typedef void (*LLAsyncHostByNameCallback)(BOOL success, const LLString& domain_name, U32 ip, void*); - -class LLAsyncHostByName -{ -public: - LLAsyncHostByName(); - ~LLAsyncHostByName(); - - BOOL startRequest( const LLString& domain_name, LLAsyncHostByNameCallback callback, void* userdata ); - - BOOL isPendingRequest() { return FALSE; } - BOOL cancelPendingRequest(); - -private: -}; - -extern LLAsyncHostByName gAsyncHostByName; - -#endif // !LL_WINDOWS - -#endif // LL_LLASYNCHOSTBYNAME_H diff --git a/linden/indra/newview/llaudiosourcevo.cpp b/linden/indra/newview/llaudiosourcevo.cpp index b0e0758..fac2e7b 100644 --- a/linden/indra/newview/llaudiosourcevo.cpp +++ b/linden/indra/newview/llaudiosourcevo.cpp @@ -3,6 +3,8 @@ * @author Douglas Soo, James Cook * @brief Audio sources attached to viewer objects * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -70,7 +73,23 @@ void LLAudioSourceVO::updateGain() BOOL mute = FALSE; if (gParcelMgr) { - LLVector3d pos_global = mObjectp->getPositionGlobal(); + LLVector3d pos_global; + + if (mObjectp->isAttachment()) + { + LLViewerObject* parent = mObjectp; + while (parent + && !parent->isAvatar()) + { + parent = (LLViewerObject*)parent->getParent(); + } + if (parent) + pos_global = parent->getPositionGlobal(); + } + + else + pos_global = mObjectp->getPositionGlobal(); + if (!gParcelMgr->canHearSound(pos_global)) { mute = TRUE; diff --git a/linden/indra/newview/llaudiosourcevo.h b/linden/indra/newview/llaudiosourcevo.h index ac208a3..6f24b19 100644 --- a/linden/indra/newview/llaudiosourcevo.h +++ b/linden/indra/newview/llaudiosourcevo.h @@ -3,6 +3,8 @@ * @author Douglas Soo, James Cook * @brief Audio sources attached to viewer objects * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLAUDIOSOURCEVO_H diff --git a/linden/indra/newview/llbbox.cpp b/linden/indra/newview/llbbox.cpp index 29bcf86..574d93f 100644 --- a/linden/indra/newview/llbbox.cpp +++ b/linden/indra/newview/llbbox.cpp @@ -2,6 +2,8 @@ * @file llbbox.cpp * @brief General purpose bounding box class (Not axis aligned) * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llbbox.h b/linden/indra/newview/llbbox.h index e04de42..8e26ae5 100644 --- a/linden/indra/newview/llbbox.h +++ b/linden/indra/newview/llbbox.h @@ -2,6 +2,8 @@ * @file llbbox.h * @brief General purpose bounding box class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_BBOX_H diff --git a/linden/indra/newview/llbox.cpp b/linden/indra/newview/llbox.cpp index 4eb5fa2..6f0edf7 100644 --- a/linden/indra/newview/llbox.cpp +++ b/linden/indra/newview/llbox.cpp @@ -2,6 +2,8 @@ * @file llbox.cpp * @brief Draws a box using display lists for speed. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llbox.h b/linden/indra/newview/llbox.h index 304916b..79f2f0a 100644 --- a/linden/indra/newview/llbox.h +++ b/linden/indra/newview/llbox.h @@ -2,6 +2,8 @@ * @file llbox.h * @brief Draws a box using display lists for speed. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLBOX_H diff --git a/linden/indra/newview/llcallbacklist.cpp b/linden/indra/newview/llcallbacklist.cpp index c5a7e28..f2a4573 100644 --- a/linden/indra/newview/llcallbacklist.cpp +++ b/linden/indra/newview/llcallbacklist.cpp @@ -2,6 +2,8 @@ * @file llcallbacklist.cpp * @brief A simple list of callback functions to call. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llcallbacklist.h b/linden/indra/newview/llcallbacklist.h index 84dccfa..9ff0218 100644 --- a/linden/indra/newview/llcallbacklist.h +++ b/linden/indra/newview/llcallbacklist.h @@ -2,6 +2,8 @@ * @file llcallbacklist.h * @brief A simple list of callback functions to call. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCALLBACKLIST_H diff --git a/linden/indra/newview/llcallingcard.cpp b/linden/indra/newview/llcallingcard.cpp index dfc99bf..b80c2bb 100644 --- a/linden/indra/newview/llcallingcard.cpp +++ b/linden/indra/newview/llcallingcard.cpp @@ -2,6 +2,8 @@ * @file llcallingcard.cpp * @brief Implementation of the LLPreviewCallingCard class * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -678,7 +681,6 @@ void LLAvatarTracker::processNotify(LLMessageSystem* msg, bool online) } } -// XUI:translate void LLAvatarTracker::formFriendship(const LLUUID& id) { if(id.notNull()) @@ -846,3 +848,4 @@ bool LLCollectAllBuddies::operator()(const LLUUID& buddy_id, LLRelationship* bud return true; } + diff --git a/linden/indra/newview/llcallingcard.h b/linden/indra/newview/llcallingcard.h index 2d36324..f713af3 100644 --- a/linden/indra/newview/llcallingcard.h +++ b/linden/indra/newview/llcallingcard.h @@ -2,6 +2,8 @@ * @file llcallingcard.h * @brief Definition of the LLPreviewCallingCard class * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCALLINGCARD_H diff --git a/linden/indra/newview/llcameraview.cpp b/linden/indra/newview/llcameraview.cpp index d9bd282..6db0f20 100644 --- a/linden/indra/newview/llcameraview.cpp +++ b/linden/indra/newview/llcameraview.cpp @@ -2,6 +2,8 @@ * @file llcameraview.cpp * @brief Container for movement buttons like forward, left, fly * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llcameraview.h b/linden/indra/newview/llcameraview.h index 32c29e8..3c46ffb 100644 --- a/linden/indra/newview/llcameraview.h +++ b/linden/indra/newview/llcameraview.h @@ -2,6 +2,8 @@ * @file llcameraview.h * @brief Container for buttons for walking, turning, flying * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // llcameraview.h diff --git a/linden/indra/newview/llcape.cpp b/linden/indra/newview/llcape.cpp index 91f4ee7..29e8b89 100644 --- a/linden/indra/newview/llcape.cpp +++ b/linden/indra/newview/llcape.cpp @@ -2,6 +2,8 @@ * @file llcape.cpp * @brief LLVOCloth class implementation * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llcape.h b/linden/indra/newview/llcape.h index f491a61..6efb56b 100644 --- a/linden/indra/newview/llcape.h +++ b/linden/indra/newview/llcape.h @@ -2,6 +2,8 @@ * @file llcape.h * @brief LLVOCloth class definition * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLCAPE_H diff --git a/linden/indra/newview/llcaphttpsender.cpp b/linden/indra/newview/llcaphttpsender.cpp index cea8198..f34711a 100644 --- a/linden/indra/newview/llcaphttpsender.cpp +++ b/linden/indra/newview/llcaphttpsender.cpp @@ -2,7 +2,9 @@ * @file llcaphttpsender.cpp * @brief Abstracts details of sending messages via UntrustedMessage cap. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llcaphttpsender.h b/linden/indra/newview/llcaphttpsender.h index c482c41..222aa77 100644 --- a/linden/indra/newview/llcaphttpsender.h +++ b/linden/indra/newview/llcaphttpsender.h @@ -3,7 +3,9 @@ * @brief Abstracts details of sending messages via the * UntrustedMessage capability. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_CAP_HTTP_SENDER_H diff --git a/linden/indra/newview/llchatbar.cpp b/linden/indra/newview/llchatbar.cpp index 38ae97b..3517c1e 100644 --- a/linden/indra/newview/llchatbar.cpp +++ b/linden/indra/newview/llchatbar.cpp @@ -2,6 +2,8 @@ * @file llchatbar.cpp * @brief LLChatBar class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -453,7 +456,7 @@ LLWString LLChatBar::stripChannelNumber(const LLWString &mesg, S32* channel) } else if (mesg[0] == '/' && mesg[1] - && isdigit(mesg[1])) + && LLStringOps::isDigit(mesg[1])) { // This a special "/20" speak on a channel S32 pos = 0; @@ -467,7 +470,7 @@ LLWString LLChatBar::stripChannelNumber(const LLWString &mesg, S32* channel) channel_string[pos] = c; pos++; } - while(c && pos < 64 && isdigit(c)); + while(c && pos < 64 && LLStringOps::isDigit(c)); // Move the pointer forward to the first non-whitespace char // Check isspace before looping, so we can handle "/33foo" diff --git a/linden/indra/newview/llchatbar.h b/linden/indra/newview/llchatbar.h index 8a5acc6..76a8012 100644 --- a/linden/indra/newview/llchatbar.h +++ b/linden/indra/newview/llchatbar.h @@ -2,6 +2,8 @@ * @file llchatbar.h * @brief LLChatBar class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCHATBAR_H diff --git a/linden/indra/newview/llclassifiedinfo.cpp b/linden/indra/newview/llclassifiedinfo.cpp index 5d35dcc..a49af23 100644 --- a/linden/indra/newview/llclassifiedinfo.cpp +++ b/linden/indra/newview/llclassifiedinfo.cpp @@ -2,6 +2,8 @@ * @file llclassifiedinfo.cpp * @brief LLClassifiedInfo class definition * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llclassifiedinfo.h b/linden/indra/newview/llclassifiedinfo.h index 6314fff..f916c3a 100644 --- a/linden/indra/newview/llclassifiedinfo.h +++ b/linden/indra/newview/llclassifiedinfo.h @@ -2,6 +2,8 @@ * @file llclassifiedinfo.h * @brief LLClassifiedInfo class definition * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCLASSIFIEDINFO_H diff --git a/linden/indra/newview/llcloud.cpp b/linden/indra/newview/llcloud.cpp index ec148cc..b3b6b41 100644 --- a/linden/indra/newview/llcloud.cpp +++ b/linden/indra/newview/llcloud.cpp @@ -2,6 +2,8 @@ * @file llcloud.cpp * @brief Implementation of viewer LLCloudLayer class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llcloud.h b/linden/indra/newview/llcloud.h index 52bbdaf..1943cac 100644 --- a/linden/indra/newview/llcloud.h +++ b/linden/indra/newview/llcloud.h @@ -2,6 +2,8 @@ * @file llcloud.h * @brief Description of viewer LLCloudLayer class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCLOUD_H diff --git a/linden/indra/newview/llcolorscheme.cpp b/linden/indra/newview/llcolorscheme.cpp index 8b271b0..111aaf2 100644 --- a/linden/indra/newview/llcolorscheme.cpp +++ b/linden/indra/newview/llcolorscheme.cpp @@ -2,6 +2,8 @@ * @file llcolorscheme.cpp * @brief Implementation of colors used for map * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -35,6 +38,7 @@ LLColor4 gTrackColor; LLColor4 gSelfMapColor; LLColor4 gAvatarMapColor; +LLColor4 gFriendMapColor; LLColor4 gLandmarkMapColor; LLColor4 gLocationMapColor; LLColor4 gTelehubMapColor; @@ -53,6 +57,7 @@ void init_colors() gSelfMapColor = LLColor4::white; gAvatarMapColor = LLColor4::green; + gFriendMapColor = LLColor4::yellow; // fleshy color //gAvatarMapColor.setVec( 255.f/255.f, 223.f/255.f, 170.f/255.f, 1.f); diff --git a/linden/indra/newview/llcolorscheme.h b/linden/indra/newview/llcolorscheme.h index 5fd7c93..d4aa411 100644 --- a/linden/indra/newview/llcolorscheme.h +++ b/linden/indra/newview/llcolorscheme.h @@ -2,6 +2,8 @@ * @file llcolorscheme.h * @brief Definition of colors used for map * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCOLORSCHEME_H @@ -34,6 +37,7 @@ extern LLColor4 gTrackColor; extern LLColor4 gSelfMapColor; extern LLColor4 gAvatarMapColor; +extern LLColor4 gFriendMapColor; extern LLColor4 gLandmarkMapColor; extern LLColor4 gLocationMapColor; extern LLColor4 gTelehubMapColor; diff --git a/linden/indra/newview/llcolorswatch.cpp b/linden/indra/newview/llcolorswatch.cpp index 2503649..b814f0d 100644 --- a/linden/indra/newview/llcolorswatch.cpp +++ b/linden/indra/newview/llcolorswatch.cpp @@ -2,6 +2,8 @@ * @file llcolorswatch.cpp * @brief LLColorSwatch class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llcolorswatch.h b/linden/indra/newview/llcolorswatch.h index 710d332..05b2dc4 100644 --- a/linden/indra/newview/llcolorswatch.h +++ b/linden/indra/newview/llcolorswatch.h @@ -2,6 +2,8 @@ * @file llcolorswatch.h * @brief LLColorSwatch class definition * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCOLORSWATCH_H diff --git a/linden/indra/newview/llcommandhandler.cpp b/linden/indra/newview/llcommandhandler.cpp new file mode 100644 index 0000000..fd3aef9 --- /dev/null +++ b/linden/indra/newview/llcommandhandler.cpp @@ -0,0 +1,103 @@ +/** + * @file llcommandhandler.cpp + * @brief Central registry for text-driven "commands", most of + * which manipulate user interface. For example, the command + * "agent (uuid) about" will open the UI for an avatar's profile. + * + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. + * + * Second Life Viewer Source Code + * The source code in this file ("Source Code") is provided by Linden Lab + * to you under the terms of the GNU General Public License, version 2.0 + * ("GPL"), unless you have obtained a separate licensing agreement + * ("Other License"), formally executed by you and Linden Lab. Terms of + * the GPL can be found in doc/GPL-license.txt in this distribution, or + * online at http://secondlife.com/developers/opensource/gplv2 + * + * There are special exceptions to the terms and conditions of the GPL as + * it is applied to this Source Code. View the full text of the exception + * in the file doc/FLOSS-exception.txt in this software distribution, or + * online at http://secondlife.com/developers/opensource/flossexception + * + * By copying, modifying or distributing this software, you acknowledge + * that you have read and understood your obligations described above, + * and agree to abide by those obligations. + * + * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO + * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, + * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ + */ +#include "llviewerprecompiledheaders.h" + +#include "llcommandhandler.h" + +// system includes +#include + +//--------------------------------------------------------------------------- +// Underlying registry for command handlers, not directly accessible. +//--------------------------------------------------------------------------- + +class LLCommandHandlerRegistry +{ +public: + static LLCommandHandlerRegistry& instance(); + void add(const char* cmd, LLCommandHandler* handler); + bool dispatch(const std::string& cmd, const std::vector& params); + +private: + std::map mMap; +}; + +// static +LLCommandHandlerRegistry& LLCommandHandlerRegistry::instance() +{ + // Force this to be initialized on first call, because we're going + // to be adding items to the std::map before main() and we can't + // rely on a global being initialized in the right order. + static LLCommandHandlerRegistry instance; + return instance; +} + +void LLCommandHandlerRegistry::add(const char* cmd, LLCommandHandler* handler) +{ + mMap[cmd] = handler; +} + +bool LLCommandHandlerRegistry::dispatch(const std::string& cmd, + const std::vector& params) +{ + std::map::iterator it = mMap.find(cmd); + if (it == mMap.end()) return false; + LLCommandHandler* handler = it->second; + if (!handler) return false; + return handler->handle(params); +} + +//--------------------------------------------------------------------------- +// Automatic registration of commands, runs before main() +//--------------------------------------------------------------------------- + +LLCommandHandler::LLCommandHandler(const char* cmd) +{ + LLCommandHandlerRegistry::instance().add(cmd, this); +} + +LLCommandHandler::~LLCommandHandler() +{ + // Don't care about unregistering these, all the handlers + // should be static objects. +} + +//--------------------------------------------------------------------------- +// Public interface +//--------------------------------------------------------------------------- + +// static +bool LLCommandDispatcher::dispatch(const std::string& cmd, const std::vector& params) +{ + return LLCommandHandlerRegistry::instance().dispatch(cmd, params); +} diff --git a/linden/indra/newview/llcommandhandler.h b/linden/indra/newview/llcommandhandler.h new file mode 100644 index 0000000..50928e2 --- /dev/null +++ b/linden/indra/newview/llcommandhandler.h @@ -0,0 +1,85 @@ +/** + * @file llcommandhandler.h + * @brief Central registry for text-driven "commands", most of + * which manipulate user interface. For example, the command + * "agent (uuid) about" will open the UI for an avatar's profile. + * + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. + * + * Second Life Viewer Source Code + * The source code in this file ("Source Code") is provided by Linden Lab + * to you under the terms of the GNU General Public License, version 2.0 + * ("GPL"), unless you have obtained a separate licensing agreement + * ("Other License"), formally executed by you and Linden Lab. Terms of + * the GPL can be found in doc/GPL-license.txt in this distribution, or + * online at http://secondlife.com/developers/opensource/gplv2 + * + * There are special exceptions to the terms and conditions of the GPL as + * it is applied to this Source Code. View the full text of the exception + * in the file doc/FLOSS-exception.txt in this software distribution, or + * online at http://secondlife.com/developers/opensource/flossexception + * + * By copying, modifying or distributing this software, you acknowledge + * that you have read and understood your obligations described above, + * and agree to abide by those obligations. + * + * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO + * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, + * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ + */ +#ifndef LLCOMMANDHANDLER_H +#define LLCOMMANDHANDLER_H + +/* To implement a command "foo" that takes one parameter, + a UUID, do this: + +class LLFooHandler : public LLCommandHandler +{ +public: + // Inform the system you handle commands starting + // with "foo" + LLFooHandler() : LLCommandHandler("foo") { } + + // Your code here + bool handle(const std::vector& tokens) + { + if (tokens.size() < 1) return false; + LLUUID id( tokens[0] ); + return doFoo(id); + } +}; + +// Creating the object registers with the dispatcher. +LLFooHandler gFooHandler; +*/ + +class LLCommandHandler +{ +public: + LLCommandHandler(const char* command); + // Automatically registers object to get called when + // command is executed. + + virtual ~LLCommandHandler(); + + virtual bool handle(const std::vector& params) = 0; + // Execute the command with a provided (possibly empty) + // list of parameters. + // Return true if you did something, false if the parameters + // are invalid or on error. +}; + + +class LLCommandDispatcher +{ +public: + static bool dispatch(const std::string& cmd, const std::vector& params); + // Execute a command registered via the above mechanism, + // passing string parameters. + // Returns true if command was found and executed correctly. +}; + +#endif diff --git a/linden/indra/newview/llcompass.cpp b/linden/indra/newview/llcompass.cpp index 125ae10..b9e1d0e 100644 --- a/linden/indra/newview/llcompass.cpp +++ b/linden/indra/newview/llcompass.cpp @@ -2,6 +2,8 @@ * @file llcompass.cpp * @brief A little map of the world with network information * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llcompass.h b/linden/indra/newview/llcompass.h index d23046d..d158770 100644 --- a/linden/indra/newview/llcompass.h +++ b/linden/indra/newview/llcompass.h @@ -2,6 +2,8 @@ * @file llcompass.h * @brief A little map of the world with network information * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCOMPASS_H diff --git a/linden/indra/newview/llcompilequeue.cpp b/linden/indra/newview/llcompilequeue.cpp index 2bd2f2d..cebd51d 100644 --- a/linden/indra/newview/llcompilequeue.cpp +++ b/linden/indra/newview/llcompilequeue.cpp @@ -2,6 +2,8 @@ * @file llcompilequeue.cpp * @brief LLCompileQueueData class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /** @@ -56,13 +59,11 @@ #include "llviewerstats.h" #include "llvieweruictrlfactory.h" -// XUI:translate - ///---------------------------------------------------------------------------- /// Local function declarations, constants, enums, and typedefs ///---------------------------------------------------------------------------- -// XUI:translate +// *TODO:Translate const char* COMPILE_QUEUE_TITLE = "Recompilation Progress"; const char* COMPILE_START_STRING = "recompile"; const char* RESET_QUEUE_TITLE = "Reset Progress"; diff --git a/linden/indra/newview/llcompilequeue.h b/linden/indra/newview/llcompilequeue.h index cbff4cb..ca5589f 100644 --- a/linden/indra/newview/llcompilequeue.h +++ b/linden/indra/newview/llcompilequeue.h @@ -2,6 +2,8 @@ * @file llcompilequeue.h * @brief LLCompileQueue class header file * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCOMPILEQUEUE_H diff --git a/linden/indra/newview/llconfirmationmanager.cpp b/linden/indra/newview/llconfirmationmanager.cpp index 705e306..1c62b70 100644 --- a/linden/indra/newview/llconfirmationmanager.cpp +++ b/linden/indra/newview/llconfirmationmanager.cpp @@ -2,6 +2,8 @@ * @file llconfirmationmanager.cpp * @brief LLConfirmationManager class implementation * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llconfirmationmanager.h b/linden/indra/newview/llconfirmationmanager.h index 46d9992..a46360e 100644 --- a/linden/indra/newview/llconfirmationmanager.h +++ b/linden/indra/newview/llconfirmationmanager.h @@ -2,6 +2,8 @@ * @file llconfirmationmanager.h * @brief LLConfirmationManager class definition * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCONFIRMATIONMANAGER_H diff --git a/linden/indra/newview/llconsole.cpp b/linden/indra/newview/llconsole.cpp index 47d239f..aebecf5 100644 --- a/linden/indra/newview/llconsole.cpp +++ b/linden/indra/newview/llconsole.cpp @@ -2,6 +2,8 @@ * @file llconsole.cpp * @brief a scrolling console output device * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llconsole.h b/linden/indra/newview/llconsole.h index 20fb545..7206457 100644 --- a/linden/indra/newview/llconsole.h +++ b/linden/indra/newview/llconsole.h @@ -2,6 +2,8 @@ * @file llconsole.h * @brief a simple console-style output device * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCONSOLE_H diff --git a/linden/indra/newview/llcontainerview.cpp b/linden/indra/newview/llcontainerview.cpp index 3afc63f..8e58ba9 100644 --- a/linden/indra/newview/llcontainerview.cpp +++ b/linden/indra/newview/llcontainerview.cpp @@ -2,6 +2,8 @@ * @file llcontainerview.cpp * @brief Container for all statistics info * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llcontainerview.h b/linden/indra/newview/llcontainerview.h index a25439c..6160bab 100644 --- a/linden/indra/newview/llcontainerview.h +++ b/linden/indra/newview/llcontainerview.h @@ -2,6 +2,8 @@ * @file llcontainerview.h * @brief Container for all statistics info. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCONTAINERVIEW_H diff --git a/linden/indra/newview/llcontroldef.cpp b/linden/indra/newview/llcontroldef.cpp index 351f437..7c3e8d7 100644 --- a/linden/indra/newview/llcontroldef.cpp +++ b/linden/indra/newview/llcontroldef.cpp @@ -3,6 +3,8 @@ * @author James Cook * @brief Viewer control settings * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Put default viewer settings in here @@ -333,6 +336,8 @@ void declare_settings() gSavedSettings.declareString("VoiceImageLevel5", "29de489d-0491-fb00-7dab-f9e686d31e83", "Texture UUID for voice image level 5"); gSavedSettings.declareString("VoiceImageLevel6", "29de489d-0491-fb00-7dab-f9e686d31e83", "Texture UUID for voice image level 6"); + gSavedSettings.declareString("VoiceHost", "127.0.0.1", "Client SLVoice host to connect to"); + gSavedSettings.declareU32("VoicePort", 44124, "Client SLVoice port to connect to"); //------------------------------------------------------------------------ // Caution Script Permission Prompts @@ -632,6 +637,9 @@ void declare_settings() gSavedSettings.declareBOOL("CreateToolCopyCenters", TRUE, "", NO_PERSIST); gSavedSettings.declareBOOL("CreateToolCopyRotates", FALSE, "", NO_PERSIST); + gSavedSettings.declareBOOL("QuietSnapshotsToDisk", FALSE, "Take snapshots to disk without playing animation or sound"); + gSavedSettings.declareBOOL("DisableCameraConstraints", FALSE, "Disable the normal bounds put on the camera by avatar position"); + //gSavedSettings.declareBOOL("LogTimestamps", FALSE, "[NOT USED]"); //gSavedSettings.declareBOOL("AgentUpdateMouseQuery", FALSE, "[NOT USED]"); gSavedSettings.declareBOOL("AutoLogin", FALSE, "Login automatically using last username/password combination"); @@ -823,6 +831,9 @@ void declare_settings() gSavedSettings.declareBOOL("KeepAspectForSnapshot", FALSE, "Use full window when taking snapshot, regardless of requested image size" ); gSavedSettings.declareBOOL("AutoSnapshot", TRUE, "Update snapshot when camera stops moving, or any parameter changes" ); gSavedSettings.declareS32("LastSnapshotType", 0, "Select this as next type of snapshot to take (0 = postcard, 1 = texture, 2 = local image)" ); + gSavedSettings.declareS32("LastSnapshotWidth", 1024, "The width of the last snapshot, in px" ); + gSavedSettings.declareS32("LastSnapshotHeight", 768, "The height of the last snapshot, in px" ); + gSavedSettings.declareS32("SnapshotPostcardLastResolution", 0, "Take next postcard snapshot at this resolution" ); gSavedSettings.declareS32("SnapshotTextureLastResolution", 0, "Take next texture snapshot at this resolution" ); gSavedSettings.declareS32("SnapshotLocalLastResolution", 0, "Take next local snapshot at this resolution" ); @@ -912,6 +923,10 @@ void declare_settings() // Map floater gSavedSettings.declareRect("FloaterMapRect", LLRect(0, 225, 200, 0), "Rectangle for world map"); + //Lag-o-Meter floater + gSavedSettings.declareRect("FloaterLagMeter", LLRect(0, 142, 350, 0), "Rectangle for lag meter"); + gSavedSettings.declareBOOL("LagMeterShrunk", FALSE, "Last large/small state for lag meter"); + gSavedSettings.declareF32("MapScale", 128.f, "World map zoom level (pixels per region)"); gSavedSettings.declareF32("MiniMapScale", 128.f, "Miniature world map zoom levle (pixels per region)"); @@ -1750,13 +1765,13 @@ class LLAudioStreamMusicListener: public LLSimpleListener { if (gParcelMgr && gParcelMgr->getAgentParcel() - && gParcelMgr->getAgentParcel()->getMusicURL()) + && !gParcelMgr->getAgentParcel()->getMusicURL().empty()) { // if stream is already playing, don't call this // otherwise music will briefly stop if ( ! gAudiop->isInternetStreamPlaying() ) { - gAudiop->startInternetStream(gParcelMgr->getAgentParcel()->getMusicURL()); + gAudiop->startInternetStream(gParcelMgr->getAgentParcel()->getMusicURL().c_str()); } } } @@ -1784,8 +1799,8 @@ class LLAudioStreamMediaListener: public LLSimpleListener gMessageSystem->setHandlerFunc ( "ParcelMediaCommandMessage", LLMediaEngine::process_parcel_media ); gMessageSystem->setHandlerFunc ( "ParcelMediaUpdate", LLMediaEngine::process_parcel_media_update ); if ( ( gParcelMgr ) && - ( gParcelMgr->getAgentParcel () ) && - ( gParcelMgr->getAgentParcel()->getMediaURL () ) ) + ( gParcelMgr->getAgentParcel () ) && + ( !gParcelMgr->getAgentParcel()->getMediaURL().empty() ) ) { prepare_video ( gParcelMgr->getAgentParcel () ); } diff --git a/linden/indra/newview/llcubemap.cpp b/linden/indra/newview/llcubemap.cpp index ff8f7c3..f50075a 100644 --- a/linden/indra/newview/llcubemap.cpp +++ b/linden/indra/newview/llcubemap.cpp @@ -2,6 +2,8 @@ * @file llcubemap.cpp * @brief LLCubeMap class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llcubemap.h b/linden/indra/newview/llcubemap.h index 911248f..9ce0bb7 100644 --- a/linden/indra/newview/llcubemap.h +++ b/linden/indra/newview/llcubemap.h @@ -2,6 +2,8 @@ * @file llcubemap.h * @brief LLCubeMap class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCUBEMAP_H diff --git a/linden/indra/newview/llcurrencyuimanager.cpp b/linden/indra/newview/llcurrencyuimanager.cpp index 0469d5f..1e97df0 100644 --- a/linden/indra/newview/llcurrencyuimanager.cpp +++ b/linden/indra/newview/llcurrencyuimanager.cpp @@ -2,6 +2,8 @@ * @file llcurrencyuimanager.cpp * @brief LLCurrencyUIManager class implementation * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -377,7 +380,7 @@ void LLCurrencyUIManager::Impl::updateUI() { if (!mZeroMessage.empty() && mUserCurrencyBuy == 0) { - lindenAmount->setText(""); + lindenAmount->setText(LLString::null); } else { @@ -456,20 +459,20 @@ bool LLCurrencyUIManager::process() return changed; } -void LLCurrencyUIManager::buy() +void LLCurrencyUIManager::buy(const LLString& buy_msg) { if (!canBuy()) { return; } - // XUI:translate + LLUIString msg = buy_msg; + msg.setArg("[LINDENS]", llformat("%d", impl.mUserCurrencyBuy)); + msg.setArg("[USD]", llformat("%#.2f", impl.mSiteCurrencyEstimatedCost / 100.0)); LLConfirmationManager::confirm(impl.mSiteConfirm, - llformat("Buy L$ %d for approx. US$ %#.2f\n", - impl.mUserCurrencyBuy, - impl.mSiteCurrencyEstimatedCost / 100.0), - impl, - &LLCurrencyUIManager::Impl::startCurrencyBuy); + msg, + impl, + &LLCurrencyUIManager::Impl::startCurrencyBuy); } @@ -515,3 +518,4 @@ std::string LLCurrencyUIManager::errorURI() return impl.mErrorURI; } + diff --git a/linden/indra/newview/llcurrencyuimanager.h b/linden/indra/newview/llcurrencyuimanager.h index 25e8334..bb135d0 100644 --- a/linden/indra/newview/llcurrencyuimanager.h +++ b/linden/indra/newview/llcurrencyuimanager.h @@ -2,6 +2,8 @@ * @file llcurrencyuimanager.h * @brief LLCurrencyUIManager class definition * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCURRENCYUIMANAGER_H @@ -68,7 +71,7 @@ public: // call periodically, for example, from draw() // returns true if the UI needs to be updated - void buy(); + void buy(const LLString& buy_msg); // call to initiate the purchase bool inProcess(); // is a transaction in process @@ -90,3 +93,4 @@ private: #endif + diff --git a/linden/indra/newview/llcylinder.cpp b/linden/indra/newview/llcylinder.cpp index e7bb75a..58a80c2 100644 --- a/linden/indra/newview/llcylinder.cpp +++ b/linden/indra/newview/llcylinder.cpp @@ -2,6 +2,8 @@ * @file llcylinder.cpp * @brief Draws a cylinder using display lists for speed. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llcylinder.h b/linden/indra/newview/llcylinder.h index ff44128..e71cc1d 100644 --- a/linden/indra/newview/llcylinder.h +++ b/linden/indra/newview/llcylinder.h @@ -2,6 +2,8 @@ * @file llcylinder.h * @brief Draws a cylinder, and a cone, which is a special case cylinder * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLCYLINDER_H diff --git a/linden/indra/newview/lldebugmessagebox.cpp b/linden/indra/newview/lldebugmessagebox.cpp index b1f44e9..de185e2 100644 --- a/linden/indra/newview/lldebugmessagebox.cpp +++ b/linden/indra/newview/lldebugmessagebox.cpp @@ -2,6 +2,8 @@ * @file lldebugmessagebox.cpp * @brief Implementation of a simple, non-modal message box. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -215,22 +218,22 @@ void LLDebugVarMessageBox::onClose(bool app_quitting) void LLDebugVarMessageBox::draw() { - char text[128]; /*Flawfinder: ignore*/ + LLString text; switch(mVarType) { - case VAR_TYPE_F32: - snprintf(text, sizeof(text), "%.3f", *((F32*)mVarData)); /* Flawfinder: ignore */ - break; - case VAR_TYPE_S32: - snprintf(text, sizeof(text), "%d", *((S32*)mVarData)); /* Flawfinder: ignore */ + case VAR_TYPE_F32: + text = llformat("%.3f", *((F32*)mVarData)); break; - case VAR_TYPE_VEC3: - { - LLVector3* vec_p = (LLVector3*)mVarData; - snprintf(text, sizeof(text), "%.3f %.3f %.3f", vec_p->mV[VX], vec_p->mV[VY], vec_p->mV[VZ]); /* Flawfinder: ignore */ + case VAR_TYPE_S32: + text = llformat("%d", *((S32*)mVarData)); break; - } - default: + case VAR_TYPE_VEC3: + { + LLVector3* vec_p = (LLVector3*)mVarData; + text= llformat("%.3f %.3f %.3f", vec_p->mV[VX], vec_p->mV[VY], vec_p->mV[VZ]); + break; + } + default: llwarns << "Unhandled var type " << mVarType << llendl; break; } diff --git a/linden/indra/newview/lldebugmessagebox.h b/linden/indra/newview/lldebugmessagebox.h index 6eb34d2..d90d7b1 100644 --- a/linden/indra/newview/lldebugmessagebox.h +++ b/linden/indra/newview/lldebugmessagebox.h @@ -2,6 +2,8 @@ * @file lldebugmessagebox.h * @brief Debug message box. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ diff --git a/linden/indra/newview/lldebugview.cpp b/linden/indra/newview/lldebugview.cpp index 861a5bb..0921941 100644 --- a/linden/indra/newview/lldebugview.cpp +++ b/linden/indra/newview/lldebugview.cpp @@ -2,6 +2,8 @@ * @file lldebugview.cpp * @brief A view containing UI elements only visible in build mode. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lldebugview.h b/linden/indra/newview/lldebugview.h index b82fc10..075e8d7 100644 --- a/linden/indra/newview/lldebugview.h +++ b/linden/indra/newview/lldebugview.h @@ -2,6 +2,8 @@ * @file lldebugview.h * @brief A view containing debug UI elements * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDEBUGVIEW_H diff --git a/linden/indra/newview/lldirpicker.cpp b/linden/indra/newview/lldirpicker.cpp index fba3782..a63c687 100644 --- a/linden/indra/newview/lldirpicker.cpp +++ b/linden/indra/newview/lldirpicker.cpp @@ -2,6 +2,8 @@ * @file lldirpicker.cpp * @brief OS-specific file picker * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -37,6 +40,10 @@ #include "lldir.h" #include "llframetimer.h" +#if LL_LINUX +# include "llfilepicker.h" +#endif + // // Globals // @@ -257,6 +264,56 @@ void LLDirPicker::reset() mDir = NULL; } +#elif LL_LINUX + +LLDirPicker::LLDirPicker() +{ + mFilePicker = new LLFilePicker(); + reset(); +} + +LLDirPicker::~LLDirPicker() +{ + delete mFilePicker; +} + + +void LLDirPicker::reset() +{ + if (mFilePicker) + mFilePicker->reset(); +} + +BOOL LLDirPicker::getDir(LLString* filename) +{ + reset(); + if (mFilePicker) + { + GtkWindow* picker = mFilePicker->buildFilePicker(false, true, + "dirpicker"); + + if (picker) + { + gtk_window_set_title(GTK_WINDOW(picker), "Choose Directory"); + gtk_widget_show_all(GTK_WIDGET(picker)); + gtk_main(); + return (NULL != mFilePicker->getFirstFile()); + } + } + return FALSE; +} + +LLString LLDirPicker::getDirName() +{ + if (mFilePicker) + { + const char* name = mFilePicker->getFirstFile(); + if (name) + return name; + } + return ""; +} + #else // not implemented LLDirPicker::LLDirPicker() diff --git a/linden/indra/newview/lldirpicker.h b/linden/indra/newview/lldirpicker.h index 1b9664f..0bfb362 100644 --- a/linden/indra/newview/lldirpicker.h +++ b/linden/indra/newview/lldirpicker.h @@ -2,6 +2,8 @@ * @dir lldirpicker.h * @brief OS-specific dir picker * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // OS specific dir selection dialog. This is implemented as a @@ -53,6 +56,8 @@ #include #endif +class LLFilePicker; + class LLDirPicker { public: @@ -84,6 +89,11 @@ private: #endif +#if LL_LINUX + // On Linux we just implement LLDirPicker on top of LLFilePicker + LLFilePicker *mFilePicker; +#endif + char mDirs[DIRNAME_BUFFER_SIZE]; /*Flawfinder: ignore*/ LLString* mFileName; LLString mDir; diff --git a/linden/indra/newview/lldrawable.cpp b/linden/indra/newview/lldrawable.cpp index f5f69ea..b5570b1 100644 --- a/linden/indra/newview/lldrawable.cpp +++ b/linden/indra/newview/lldrawable.cpp @@ -2,6 +2,8 @@ * @file lldrawable.cpp * @brief LLDrawable class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lldrawable.h b/linden/indra/newview/lldrawable.h index e550142..c10c49c 100644 --- a/linden/indra/newview/lldrawable.h +++ b/linden/indra/newview/lldrawable.h @@ -2,6 +2,8 @@ * @file lldrawable.h * @brief LLDrawable class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_DRAWABLE_H diff --git a/linden/indra/newview/lldrawpool.cpp b/linden/indra/newview/lldrawpool.cpp index f1feb4a..9875221 100644 --- a/linden/indra/newview/lldrawpool.cpp +++ b/linden/indra/newview/lldrawpool.cpp @@ -2,6 +2,8 @@ * @file lldrawpool.cpp * @brief LLDrawPool class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lldrawpool.h b/linden/indra/newview/lldrawpool.h index ecedc4c..cd85a55 100644 --- a/linden/indra/newview/lldrawpool.h +++ b/linden/indra/newview/lldrawpool.h @@ -2,6 +2,8 @@ * @file lldrawpool.h * @brief LLDrawPool class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDRAWPOOL_H diff --git a/linden/indra/newview/lldrawpoolalpha.cpp b/linden/indra/newview/lldrawpoolalpha.cpp index a502580..0cba2c2 100644 --- a/linden/indra/newview/lldrawpoolalpha.cpp +++ b/linden/indra/newview/lldrawpoolalpha.cpp @@ -2,6 +2,8 @@ * @file lldrawpoolalpha.cpp * @brief LLDrawPoolAlpha class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lldrawpoolalpha.h b/linden/indra/newview/lldrawpoolalpha.h index 12a3242..0e39003 100644 --- a/linden/indra/newview/lldrawpoolalpha.h +++ b/linden/indra/newview/lldrawpoolalpha.h @@ -2,6 +2,8 @@ * @file lldrawpoolalpha.h * @brief LLDrawPoolAlpha class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDRAWPOOLALPHA_H diff --git a/linden/indra/newview/lldrawpoolavatar.cpp b/linden/indra/newview/lldrawpoolavatar.cpp index ae76aeb..67a379d 100644 --- a/linden/indra/newview/lldrawpoolavatar.cpp +++ b/linden/indra/newview/lldrawpoolavatar.cpp @@ -2,6 +2,8 @@ * @file lldrawpoolavatar.cpp * @brief LLDrawPoolAvatar class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lldrawpoolavatar.h b/linden/indra/newview/lldrawpoolavatar.h index 59bc797..1aa91bb 100644 --- a/linden/indra/newview/lldrawpoolavatar.h +++ b/linden/indra/newview/lldrawpoolavatar.h @@ -2,6 +2,8 @@ * @file lldrawpoolavatar.h * @brief LLDrawPoolAvatar class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDRAWPOOLAVATAR_H diff --git a/linden/indra/newview/lldrawpoolbump.cpp b/linden/indra/newview/lldrawpoolbump.cpp index a78dc94..4de13a3 100644 --- a/linden/indra/newview/lldrawpoolbump.cpp +++ b/linden/indra/newview/lldrawpoolbump.cpp @@ -2,6 +2,8 @@ * @file lldrawpoolbump.cpp * @brief LLDrawPoolBump class implementation * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lldrawpoolbump.h b/linden/indra/newview/lldrawpoolbump.h index c41325c..15d8463 100644 --- a/linden/indra/newview/lldrawpoolbump.h +++ b/linden/indra/newview/lldrawpoolbump.h @@ -2,6 +2,8 @@ * @file lldrawpoolbump.h * @brief LLDrawPoolBump class definition * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDRAWPOOLBUMP_H @@ -87,7 +90,7 @@ enum EBumpEffect class LLStandardBumpmap { public: - LLStandardBumpmap() : mLabel("") {} + LLStandardBumpmap() : mLabel() {} LLStandardBumpmap( const char* label ) : mLabel(label) {} LLString mLabel; diff --git a/linden/indra/newview/lldrawpoolclouds.cpp b/linden/indra/newview/lldrawpoolclouds.cpp index 9598f3b..2e8719d 100644 --- a/linden/indra/newview/lldrawpoolclouds.cpp +++ b/linden/indra/newview/lldrawpoolclouds.cpp @@ -2,6 +2,8 @@ * @file lldrawpoolclouds.cpp * @brief LLDrawPoolClouds class implementation * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lldrawpoolclouds.h b/linden/indra/newview/lldrawpoolclouds.h index 00faea3..e155acf 100644 --- a/linden/indra/newview/lldrawpoolclouds.h +++ b/linden/indra/newview/lldrawpoolclouds.h @@ -2,6 +2,8 @@ * @file lldrawpoolclouds.h * @brief LLDrawPoolClouds class definition * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDRAWPOOLCLOUDS_H diff --git a/linden/indra/newview/lldrawpoolground.cpp b/linden/indra/newview/lldrawpoolground.cpp index d0557d4..d84f095 100644 --- a/linden/indra/newview/lldrawpoolground.cpp +++ b/linden/indra/newview/lldrawpoolground.cpp @@ -2,6 +2,8 @@ * @file lldrawpoolground.cpp * @brief LLDrawPoolGround class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lldrawpoolground.h b/linden/indra/newview/lldrawpoolground.h index 97938d8..a804c90 100644 --- a/linden/indra/newview/lldrawpoolground.h +++ b/linden/indra/newview/lldrawpoolground.h @@ -2,6 +2,8 @@ * @file lldrawpoolground.h * @brief LLDrawPoolGround class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDRAWPOOLGROUND_H diff --git a/linden/indra/newview/lldrawpoolsimple.cpp b/linden/indra/newview/lldrawpoolsimple.cpp index 3af8bc2..0a5d457 100644 --- a/linden/indra/newview/lldrawpoolsimple.cpp +++ b/linden/indra/newview/lldrawpoolsimple.cpp @@ -2,6 +2,8 @@ * @file lldrawpoolsimple.cpp * @brief LLDrawPoolSimple class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lldrawpoolsimple.h b/linden/indra/newview/lldrawpoolsimple.h index a482b28..ff12610 100644 --- a/linden/indra/newview/lldrawpoolsimple.h +++ b/linden/indra/newview/lldrawpoolsimple.h @@ -2,6 +2,8 @@ * @file lldrawpoolsimple.h * @brief LLDrawPoolSimple class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDRAWPOOLSIMPLE_H diff --git a/linden/indra/newview/lldrawpoolsky.cpp b/linden/indra/newview/lldrawpoolsky.cpp index 328b802..677a563 100644 --- a/linden/indra/newview/lldrawpoolsky.cpp +++ b/linden/indra/newview/lldrawpoolsky.cpp @@ -2,6 +2,8 @@ * @file lldrawpoolsky.cpp * @brief LLDrawPoolSky class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lldrawpoolsky.h b/linden/indra/newview/lldrawpoolsky.h index 645e669..ceabde3 100644 --- a/linden/indra/newview/lldrawpoolsky.h +++ b/linden/indra/newview/lldrawpoolsky.h @@ -2,6 +2,8 @@ * @file lldrawpoolsky.h * @brief LLDrawPoolSky class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDRAWPOOLSKY_H diff --git a/linden/indra/newview/lldrawpoolstars.cpp b/linden/indra/newview/lldrawpoolstars.cpp index d5d57e6..d0a0919 100644 --- a/linden/indra/newview/lldrawpoolstars.cpp +++ b/linden/indra/newview/lldrawpoolstars.cpp @@ -2,6 +2,8 @@ * @file lldrawpoolstars.cpp * @brief LLDrawPoolStars class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lldrawpoolstars.h b/linden/indra/newview/lldrawpoolstars.h index d4ddcf4..e31d8b5 100644 --- a/linden/indra/newview/lldrawpoolstars.h +++ b/linden/indra/newview/lldrawpoolstars.h @@ -2,6 +2,8 @@ * @file lldrawpoolstars.h * @brief LLDrawPoolStars class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDRAWPOOLSTARS_H diff --git a/linden/indra/newview/lldrawpoolterrain.cpp b/linden/indra/newview/lldrawpoolterrain.cpp index 7586b76..b48de1d 100644 --- a/linden/indra/newview/lldrawpoolterrain.cpp +++ b/linden/indra/newview/lldrawpoolterrain.cpp @@ -2,6 +2,8 @@ * @file lldrawpoolterrain.cpp * @brief LLDrawPoolTerrain class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lldrawpoolterrain.h b/linden/indra/newview/lldrawpoolterrain.h index 16fb4ab..dc95d7d 100644 --- a/linden/indra/newview/lldrawpoolterrain.h +++ b/linden/indra/newview/lldrawpoolterrain.h @@ -2,6 +2,8 @@ * @file lldrawpoolterrain.h * @brief LLDrawPoolTerrain class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDRAWPOOLTERRAIN_H diff --git a/linden/indra/newview/lldrawpooltree.cpp b/linden/indra/newview/lldrawpooltree.cpp index 6749178..c8e0ff2 100644 --- a/linden/indra/newview/lldrawpooltree.cpp +++ b/linden/indra/newview/lldrawpooltree.cpp @@ -2,6 +2,8 @@ * @file lldrawpooltree.cpp * @brief LLDrawPoolTree class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lldrawpooltree.h b/linden/indra/newview/lldrawpooltree.h index 82bc235..7dee238 100644 --- a/linden/indra/newview/lldrawpooltree.h +++ b/linden/indra/newview/lldrawpooltree.h @@ -2,6 +2,8 @@ * @file lldrawpooltree.h * @brief LLDrawPoolTree class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDRAWPOOLTREE_H diff --git a/linden/indra/newview/lldrawpoolwater.cpp b/linden/indra/newview/lldrawpoolwater.cpp index 035cb56..54a33f2 100644 --- a/linden/indra/newview/lldrawpoolwater.cpp +++ b/linden/indra/newview/lldrawpoolwater.cpp @@ -2,6 +2,8 @@ * @file lldrawpoolwater.cpp * @brief LLDrawPoolWater class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lldrawpoolwater.h b/linden/indra/newview/lldrawpoolwater.h index cdd3e3b..24346c4 100644 --- a/linden/indra/newview/lldrawpoolwater.h +++ b/linden/indra/newview/lldrawpoolwater.h @@ -2,6 +2,8 @@ * @file lldrawpoolwater.h * @brief LLDrawPoolWater class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDRAWPOOLWATER_H diff --git a/linden/indra/newview/lldriverparam.cpp b/linden/indra/newview/lldriverparam.cpp index 463888c..b3daad9 100644 --- a/linden/indra/newview/lldriverparam.cpp +++ b/linden/indra/newview/lldriverparam.cpp @@ -2,6 +2,8 @@ * @file lldriverparam.cpp * @brief A visual parameter that drives (controls) other visual parameters. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lldriverparam.h b/linden/indra/newview/lldriverparam.h index fb13e50..46b8609 100644 --- a/linden/indra/newview/lldriverparam.h +++ b/linden/indra/newview/lldriverparam.h @@ -2,6 +2,8 @@ * @file lldriverparam.h * @brief A visual parameter that drives (controls) other visual parameters. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDRIVERPARAM_H diff --git a/linden/indra/newview/lldynamictexture.cpp b/linden/indra/newview/lldynamictexture.cpp index 57f4def..8f6b572 100644 --- a/linden/indra/newview/lldynamictexture.cpp +++ b/linden/indra/newview/lldynamictexture.cpp @@ -2,6 +2,8 @@ * @file lldynamictexture.cpp * @brief Implementation of LLDynamicTexture class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lldynamictexture.h b/linden/indra/newview/lldynamictexture.h index 9833ecc..49c8b0c 100644 --- a/linden/indra/newview/lldynamictexture.h +++ b/linden/indra/newview/lldynamictexture.h @@ -2,6 +2,8 @@ * @file lldynamictexture.h * @brief Implementation of LLDynamicTexture class * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLDYNAMICTEXTURE_H diff --git a/linden/indra/newview/llemote.cpp b/linden/indra/newview/llemote.cpp index 09ba389..bcf45b2 100644 --- a/linden/indra/newview/llemote.cpp +++ b/linden/indra/newview/llemote.cpp @@ -2,6 +2,8 @@ * @file llemote.cpp * @brief Implementation of LLEmote class * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- diff --git a/linden/indra/newview/llemote.h b/linden/indra/newview/llemote.h index 9e2e09c..785c9df 100644 --- a/linden/indra/newview/llemote.h +++ b/linden/indra/newview/llemote.h @@ -2,6 +2,8 @@ * @file llemote.h * @brief Definition of LLEmote class * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLEMOTE_H diff --git a/linden/indra/newview/lleventinfo.cpp b/linden/indra/newview/lleventinfo.cpp index f49b91a..17b33f1 100644 --- a/linden/indra/newview/lleventinfo.cpp +++ b/linden/indra/newview/lleventinfo.cpp @@ -2,6 +2,8 @@ * @file lleventinfo.cpp * @brief LLEventInfo class implementation * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lleventinfo.h b/linden/indra/newview/lleventinfo.h index 9fd6f99..6d76b0c 100644 --- a/linden/indra/newview/lleventinfo.h +++ b/linden/indra/newview/lleventinfo.h @@ -2,6 +2,8 @@ * @file lleventinfo.h * @brief LLEventInfo class definition * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLEVENTINFO_H diff --git a/linden/indra/newview/lleventnotifier.cpp b/linden/indra/newview/lleventnotifier.cpp index ec4d95f..8e20692 100644 --- a/linden/indra/newview/lleventnotifier.cpp +++ b/linden/indra/newview/lleventnotifier.cpp @@ -2,6 +2,8 @@ * @file lleventnotifier.cpp * @brief Viewer code for managing event notifications * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lleventnotifier.h b/linden/indra/newview/lleventnotifier.h index 1db2e2f..1801efe 100644 --- a/linden/indra/newview/lleventnotifier.h +++ b/linden/indra/newview/lleventnotifier.h @@ -2,6 +2,8 @@ * @file lleventnotifier.h * @brief Viewer code for managing event notifications * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLEVENTNOTIFIER_H diff --git a/linden/indra/newview/lleventpoll.cpp b/linden/indra/newview/lleventpoll.cpp index 755c622..745d0f7 100644 --- a/linden/indra/newview/lleventpoll.cpp +++ b/linden/indra/newview/lleventpoll.cpp @@ -2,6 +2,8 @@ * @file lleventpoll.cpp * @brief Implementation of the LLEventPoll class. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -171,7 +174,8 @@ namespace llwarns << "LLEventPollResponder: id undefined" << llendl; } - llinfos << "LLEventPollResponder::completed <" << mCount << "> " << events.size() << "events (id " + // was llinfos but now that CoarseRegionUpdate is TCP @ 1/second, it'd be too verbose for viewer logs. -MG + lldebugs << "LLEventPollResponder::completed <" << mCount << "> " << events.size() << "events (id " << LLSDXMLStreamer(mAcknowledge) << ")" << llendl; LLSD::array_const_iterator i = events.beginArray(); diff --git a/linden/indra/newview/lleventpoll.h b/linden/indra/newview/lleventpoll.h index a9a533d..8b3b1e6 100644 --- a/linden/indra/newview/lleventpoll.h +++ b/linden/indra/newview/lleventpoll.h @@ -2,6 +2,8 @@ * @file lleventpoll.h * @brief LLEvDescription of the LLEventPoll class. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLEVENTPOLL_H diff --git a/linden/indra/newview/llface.cpp b/linden/indra/newview/llface.cpp index cfda05a..be19b30 100644 --- a/linden/indra/newview/llface.cpp +++ b/linden/indra/newview/llface.cpp @@ -2,6 +2,8 @@ * @file llface.cpp * @brief LLFace class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llface.h b/linden/indra/newview/llface.h index 24ef213..2a732ee 100644 --- a/linden/indra/newview/llface.h +++ b/linden/indra/newview/llface.h @@ -2,6 +2,8 @@ * @file llface.h * @brief LLFace class definition * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFACE_H diff --git a/linden/indra/newview/llface.inl b/linden/indra/newview/llface.inl index b36577e..71f0638 100644 --- a/linden/indra/newview/llface.inl +++ b/linden/indra/newview/llface.inl @@ -2,6 +2,8 @@ * @file llface.inl * @brief Inline functions for LLFace * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFACE_INL diff --git a/linden/indra/newview/llfasttimerview.cpp b/linden/indra/newview/llfasttimerview.cpp index ba1296a..424f47e 100644 --- a/linden/indra/newview/llfasttimerview.cpp +++ b/linden/indra/newview/llfasttimerview.cpp @@ -2,6 +2,8 @@ * @file llfasttimerview.cpp * @brief LLFastTimerView class implementation * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llfasttimerview.h b/linden/indra/newview/llfasttimerview.h index f4ecfcd..7e461ec 100644 --- a/linden/indra/newview/llfasttimerview.h +++ b/linden/indra/newview/llfasttimerview.h @@ -2,6 +2,8 @@ * @file llfasttimerview.h * @brief LLFastTimerView class definition * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFASTTIMERVIEW_H diff --git a/linden/indra/newview/llfeaturemanager.cpp b/linden/indra/newview/llfeaturemanager.cpp index 93450b4..6b6eacd 100644 --- a/linden/indra/newview/llfeaturemanager.cpp +++ b/linden/indra/newview/llfeaturemanager.cpp @@ -2,6 +2,8 @@ * @file llfeaturemanager.cpp * @brief LLFeatureManager class implementation * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include diff --git a/linden/indra/newview/llfeaturemanager.h b/linden/indra/newview/llfeaturemanager.h index 026b78a..21d1ee0 100644 --- a/linden/indra/newview/llfeaturemanager.h +++ b/linden/indra/newview/llfeaturemanager.h @@ -2,6 +2,8 @@ * @file llfeaturemanager.h * @brief LLFeatureManager class definition * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFEATUREMANAGER_H diff --git a/linden/indra/newview/llfilepicker.cpp b/linden/indra/newview/llfilepicker.cpp index 3620c05..c73b331 100644 --- a/linden/indra/newview/llfilepicker.cpp +++ b/linden/indra/newview/llfilepicker.cpp @@ -2,6 +2,8 @@ * @file llfilepicker.cpp * @brief OS-specific file picker * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,13 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" #include "llfilepicker.h" -//#include "viewer.h" -//#include "llviewermessage.h" #include "llworld.h" #include "llviewerwindow.h" #include "llkeyboard.h" @@ -957,6 +958,10 @@ void LLFilePicker::reset() #elif LL_LINUX # if LL_GTK +// This caches the previously-accessed path for a given context of the file +// chooser, for user convenience. +std::map LLFilePicker::sContextToPathMap; + LLFilePicker::LLFilePicker() { reset(); @@ -966,51 +971,83 @@ LLFilePicker::~LLFilePicker() { } -static void store_filenames(GtkWidget *widget, gpointer user_data) { + +static void add_to_sfs(gpointer data, gpointer user_data) +{ StoreFilenamesStruct *sfs = (StoreFilenamesStruct*) user_data; - GtkWidget *win = sfs->win; + gchar* filename_utf8 = g_filename_to_utf8((gchar*)data, + -1, NULL, + NULL, + NULL); + sfs->fileVector.push_back(LLString(filename_utf8)); + g_free(filename_utf8); +} - llinfos <<"store_filesnames: marker A" << llendl; - // get NULL-terminated list of strings allocated for us by GTK - gchar** string_list = - gtk_file_selection_get_selections(GTK_FILE_SELECTION(win)); +void chooser_responder(GtkWidget *widget, + gint response, + gpointer user_data) { + StoreFilenamesStruct *sfs = (StoreFilenamesStruct*) user_data; - llinfos <<"store_filesnames: marker B" << llendl; + lldebugs << "GTK DIALOG RESPONSE " << response << llendl; - int idx = 0; - while (string_list[idx]) + if (response == GTK_RESPONSE_ACCEPT) { - // platform-string to utf8 - gchar* filename_utf8 = g_filename_from_utf8(string_list[idx], - -1, NULL, - NULL, - NULL); - sfs->fileVector.push_back(LLString(filename_utf8)); - ++idx; + GSList *file_list = gtk_file_chooser_get_filenames(GTK_FILE_CHOOSER(widget)); + g_slist_foreach(file_list, (GFunc)add_to_sfs, sfs); + g_slist_foreach(file_list, (GFunc)g_free, NULL); + g_slist_free (file_list); } - llinfos <<"store_filesnames: marker C" << llendl; - - g_strfreev(string_list); + // set the default path for this usage context. + LLFilePicker::sContextToPathMap[sfs->contextName] = + gtk_file_chooser_get_current_folder(GTK_FILE_CHOOSER(widget)); - llinfos <<"store_filesnames: marker D" << llendl; - - llinfos << sfs->fileVector.size() << " filename(s) selected:" << llendl; - U32 x; - for (x=0; xfileVector.size(); ++x) - llinfos << x << ":" << sfs->fileVector[x] << llendl; + gtk_widget_destroy(widget); + gtk_main_quit(); } -GtkWindow* LLFilePicker::buildFilePicker(void) + +GtkWindow* LLFilePicker::buildFilePicker(bool is_save, bool is_folder, + std::string context) { if (ll_try_gtk_init() && ! gViewerWindow->getWindow()->getFullscreen()) { GtkWidget *win = NULL; - - win = gtk_file_selection_new(NULL); + GtkFileChooserAction pickertype = + is_save? + (is_folder? + GTK_FILE_CHOOSER_ACTION_CREATE_FOLDER : + GTK_FILE_CHOOSER_ACTION_SAVE) : + (is_folder? + GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER : + GTK_FILE_CHOOSER_ACTION_OPEN); + + win = gtk_file_chooser_dialog_new(NULL, NULL, + pickertype, + GTK_STOCK_CANCEL, + GTK_RESPONSE_CANCEL, + is_folder ? + GTK_STOCK_APPLY : + (is_save ? + GTK_STOCK_SAVE : + GTK_STOCK_OPEN), + GTK_RESPONSE_ACCEPT, + NULL); mStoreFilenames.win = win; + mStoreFilenames.contextName = context; + + // get the default path for this usage context if it's been + // seen before. + std::map::iterator + this_path = sContextToPathMap.find(context); + if (this_path != sContextToPathMap.end()) + { + gtk_file_chooser_set_current_folder + (GTK_FILE_CHOOSER(win), + this_path->second.c_str()); + } # if LL_X11 // Make GTK tell the window manager to associate this @@ -1030,33 +1067,17 @@ GtkWindow* LLFilePicker::buildFilePicker(void) } # endif //LL_X11 - g_signal_connect (G_OBJECT(win), "destroy", - G_CALLBACK(gtk_main_quit), NULL); - - // on 'ok', grab the file selection list - g_signal_connect (GTK_FILE_SELECTION(win)->ok_button, - "clicked", - G_CALLBACK(store_filenames), + g_signal_connect (GTK_FILE_CHOOSER(win), + "response", + G_CALLBACK(chooser_responder), &mStoreFilenames); - // both 'ok' and 'cancel' will end the dialog - g_signal_connect_swapped (G_OBJECT(GTK_FILE_SELECTION(win)-> - ok_button), - "clicked", - G_CALLBACK(gtk_widget_destroy), - G_OBJECT(win)); - g_signal_connect_swapped (G_OBJECT(GTK_FILE_SELECTION(win)-> - cancel_button), - "clicked", - G_CALLBACK(gtk_widget_destroy), - G_OBJECT(win)); - - gtk_file_selection_show_fileop_buttons(GTK_FILE_SELECTION(win)); - gtk_file_selection_set_select_multiple(GTK_FILE_SELECTION(win), - FALSE); - gtk_window_set_modal(GTK_WINDOW(win), TRUE); + /* GTK 2.6: if (is_folder) + gtk_file_chooser_set_show_hidden(GTK_FILE_CHOOSER(win), + TRUE); */ + return GTK_WINDOW(win); } else @@ -1065,6 +1086,65 @@ GtkWindow* LLFilePicker::buildFilePicker(void) } } +static void add_common_filters_to_gtkchooser(GtkFileFilter *gfilter, + GtkWindow *picker, + std::string filtername) +{ + gtk_file_filter_set_name(gfilter, filtername.c_str()); + gtk_file_chooser_add_filter(GTK_FILE_CHOOSER(picker), + gfilter); + GtkFileFilter *allfilter = gtk_file_filter_new(); + gtk_file_filter_add_pattern(allfilter, "*"); + gtk_file_filter_set_name(allfilter, "All Files"); + gtk_file_chooser_add_filter(GTK_FILE_CHOOSER(picker), allfilter); + gtk_file_chooser_set_filter(GTK_FILE_CHOOSER(picker), gfilter); +} + +static std::string add_simple_pattern_filter_to_gtkchooser(GtkWindow *picker, + std::string pattern, + std::string filtername) +{ + GtkFileFilter *gfilter = gtk_file_filter_new(); + gtk_file_filter_add_pattern(gfilter, pattern.c_str()); + add_common_filters_to_gtkchooser(gfilter, picker, filtername); + return filtername; +} + +static std::string add_simple_mime_filter_to_gtkchooser(GtkWindow *picker, + std::string mime, + std::string filtername) +{ + GtkFileFilter *gfilter = gtk_file_filter_new(); + gtk_file_filter_add_mime_type(gfilter, mime.c_str()); + add_common_filters_to_gtkchooser(gfilter, picker, filtername); + return filtername; +} + +static std::string add_wav_filter_to_gtkchooser(GtkWindow *picker) +{ + return add_simple_mime_filter_to_gtkchooser(picker, "audio/x-wav", + "Sounds (*.wav)"); +} + +static std::string add_bvh_filter_to_gtkchooser(GtkWindow *picker) +{ + return add_simple_pattern_filter_to_gtkchooser(picker, "*.bvh", + "Animations (*.bvh)"); +} + +static std::string add_imageload_filter_to_gtkchooser(GtkWindow *picker) +{ + GtkFileFilter *gfilter = gtk_file_filter_new(); + gtk_file_filter_add_pattern(gfilter, "*.tga"); + gtk_file_filter_add_mime_type(gfilter, "image/jpeg"); + gtk_file_filter_add_mime_type(gfilter, "image/png"); + gtk_file_filter_add_mime_type(gfilter, "image/bmp"); + std::string filtername = "Images (*.tga; *.bmp; *.jpg; *.png)"; + add_common_filters_to_gtkchooser(gfilter, picker, filtername); + return filtername; +} + + BOOL LLFilePicker::getSaveFile( ESaveFilter filter, const char* filename ) { BOOL rtn = FALSE; @@ -1072,7 +1152,7 @@ BOOL LLFilePicker::getSaveFile( ESaveFilter filter, const char* filename ) gViewerWindow->mWindow->beforeDialog(); reset(); - GtkWindow* picker = buildFilePicker(); + GtkWindow* picker = buildFilePicker(true, false, "savefile"); if (picker) { @@ -1082,36 +1162,45 @@ BOOL LLFilePicker::getSaveFile( ESaveFilter filter, const char* filename ) switch (filter) { case FFSAVE_WAV: - caption += "Sounds (*.wav)"; - suggest_ext += ".wav"; + caption += add_wav_filter_to_gtkchooser(picker); + suggest_ext = ".wav"; break; case FFSAVE_TGA: - caption += "Targa Images (*.tga)"; - suggest_ext += ".tga"; + caption += add_simple_pattern_filter_to_gtkchooser + (picker, "*.tga", "Targa Images (*.tga)"); + suggest_ext = ".tga"; break; case FFSAVE_BMP: - caption += "Bitmap Images (*.bmp)"; - suggest_ext += ".bmp"; + caption += add_simple_mime_filter_to_gtkchooser + (picker, "image/bmp", "Bitmap Images (*.bmp)"); + suggest_ext = ".bmp"; break; case FFSAVE_AVI: - caption += "AVI Movie File (*.avi)"; - suggest_ext += ".avi"; + caption += add_simple_mime_filter_to_gtkchooser + (picker, "video/x-msvideo", + "AVI Movie File (*.avi)"); + suggest_ext = ".avi"; break; case FFSAVE_ANIM: - caption += "XAF Anim File (*.xaf)"; - suggest_ext += ".xaf"; + caption += add_simple_pattern_filter_to_gtkchooser + (picker, "*.xaf", "XAF Anim File (*.xaf)"); + suggest_ext = ".xaf"; break; case FFSAVE_XML: - caption += "XML File (*.xml)"; - suggest_ext += ".xml"; + caption += add_simple_pattern_filter_to_gtkchooser + (picker, "*.xml", "XML File (*.xml)"); + suggest_ext = ".xml"; break; case FFSAVE_RAW: - caption += "RAW File (*.raw)"; - suggest_ext += ".raw"; + caption += add_simple_pattern_filter_to_gtkchooser + (picker, "*.raw", "RAW File (*.raw)"); + suggest_ext = ".raw"; break; case FFSAVE_J2C: - caption += "Compressed Images (*.j2c)"; - suggest_ext += ".j2c"; + caption += add_simple_mime_filter_to_gtkchooser + (picker, "images/jp2", + "Compressed Images (*.j2c)"); + suggest_ext = ".j2c"; break; default:; break; @@ -1123,27 +1212,19 @@ BOOL LLFilePicker::getSaveFile( ESaveFilter filter, const char* filename ) { suggest_name += suggest_ext; - gtk_file_selection_set_filename - (GTK_FILE_SELECTION(picker), - g_filename_from_utf8(suggest_name.c_str(), - -1, NULL, - NULL, - NULL)); - gtk_editable_select_region(GTK_EDITABLE(GTK_FILE_SELECTION(picker)->selection_entry), 0, suggest_name.length() - suggest_ext.length() ); + gtk_file_chooser_set_current_name + (GTK_FILE_CHOOSER(picker), + suggest_name.c_str()); } else { - gtk_file_selection_set_filename - (GTK_FILE_SELECTION(picker), - g_filename_from_utf8(filename, - -1, NULL, - NULL, - NULL)); - gtk_editable_select_region(GTK_EDITABLE(GTK_FILE_SELECTION(picker)->selection_entry), 0, -1 ); + gtk_file_chooser_set_current_name + (GTK_FILE_CHOOSER(picker), filename); } gtk_widget_show_all(GTK_WIDGET(picker)); gtk_main(); + rtn = (mStoreFilenames.fileVector.size() == 1); } @@ -1159,27 +1240,34 @@ BOOL LLFilePicker::getOpenFile( ELoadFilter filter ) gViewerWindow->mWindow->beforeDialog(); reset(); - GtkWindow* picker = buildFilePicker(); + GtkWindow* picker = buildFilePicker(false, false, "openfile"); if (picker) { std::string caption = "Load "; + std::string filtername = ""; switch (filter) { case FFLOAD_WAV: - caption += "Sounds (*.wav)"; break; + filtername = add_wav_filter_to_gtkchooser(picker); + break; case FFLOAD_ANIM: - caption += "Animations (*.bvh)"; break; + filtername = add_bvh_filter_to_gtkchooser(picker); + break; case FFLOAD_IMAGE: - caption += "Images (*.tga; *.bmp; *.jpg; *.jpeg; *.png)"; break; + filtername = add_imageload_filter_to_gtkchooser(picker); + break; default:; break; } + + caption += filtername; gtk_window_set_title(GTK_WINDOW(picker), caption.c_str()); gtk_widget_show_all(GTK_WIDGET(picker)); gtk_main(); + rtn = (mStoreFilenames.fileVector.size() == 1); } @@ -1195,12 +1283,12 @@ BOOL LLFilePicker::getMultipleOpenFiles( ELoadFilter filter ) gViewerWindow->mWindow->beforeDialog(); reset(); - GtkWindow* picker = buildFilePicker(); + GtkWindow* picker = buildFilePicker(false, false, "openfile"); if (picker) { - gtk_file_selection_set_select_multiple(GTK_FILE_SELECTION(picker), - TRUE); + gtk_file_chooser_set_select_multiple (GTK_FILE_CHOOSER(picker), + TRUE); gtk_window_set_title(GTK_WINDOW(picker), "Load Files"); @@ -1241,7 +1329,8 @@ const char* LLFilePicker::getDirname() const char* fullpath = mStoreFilenames.fileVector[index].c_str(); const char* finalpart = NULL; const char* thispart = fullpath; - // walk through the string looking for the final dirsep, i.e. / + // (Hmm, is the strstr of dirsep UTF-8-correct? Yes, reckon.) + // Walk through the string looking for the final dirsep, i.e. / do { thispart = strstr(thispart, dirsep); diff --git a/linden/indra/newview/llfilepicker.h b/linden/indra/newview/llfilepicker.h index 008c96e..d4b0ebe 100644 --- a/linden/indra/newview/llfilepicker.h +++ b/linden/indra/newview/llfilepicker.h @@ -2,6 +2,8 @@ * @file llfilepicker.h * @brief OS-specific file picker * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // OS specific file selection dialog. This is implemented as a @@ -70,11 +73,16 @@ typedef struct { GtkWidget *win; std::vector fileVector; + std::string contextName; } StoreFilenamesStruct; #endif // LL_GTK class LLFilePicker { +#ifdef LL_GTK + friend class LLDirPicker; + friend void chooser_responder(GtkWidget *, gint, gpointer); +#endif // LL_GTK public: // calling this before main() is undefined static LLFilePicker& instance( void ) { return sInstance; } @@ -166,9 +174,9 @@ private: #if LL_GTK StoreFilenamesStruct mStoreFilenames; - - GtkWindow* buildFilePicker(void); U32 mNextFileIndex; + // we remember the last path that was accessed for a particular usage + static std::map sContextToPathMap; #endif char mFiles[FILENAME_BUFFER_SIZE]; /*Flawfinder: ignore*/ @@ -179,6 +187,12 @@ private: static LLFilePicker sInstance; +protected: +#if LL_GTK + GtkWindow* buildFilePicker(bool is_save, bool is_folder, + std::string context = "generic"); +#endif + public: // don't call these directly please. LLFilePicker(); diff --git a/linden/indra/newview/llfirstuse.cpp b/linden/indra/newview/llfirstuse.cpp index b6bd444..0782586 100644 --- a/linden/indra/newview/llfirstuse.cpp +++ b/linden/indra/newview/llfirstuse.cpp @@ -2,6 +2,8 @@ * @file llfirstuse.cpp * @brief Methods that spawn "first-use" dialogs * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llfirstuse.h b/linden/indra/newview/llfirstuse.h index 1edbf70..b5cf148 100644 --- a/linden/indra/newview/llfirstuse.h +++ b/linden/indra/newview/llfirstuse.h @@ -2,6 +2,8 @@ * @file llfirstuse.h * @brief Methods that spawn "first-use" dialogs. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFIRSTUSE_H diff --git a/linden/indra/newview/llflexibleobject.cpp b/linden/indra/newview/llflexibleobject.cpp index 454b40f..757cbcc 100644 --- a/linden/indra/newview/llflexibleobject.cpp +++ b/linden/indra/newview/llflexibleobject.cpp @@ -2,6 +2,8 @@ * @file llflexibleobject.cpp * @brief Flexible object implementation * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llflexibleobject.h b/linden/indra/newview/llflexibleobject.h index df2e4ac..fe20235 100644 --- a/linden/indra/newview/llflexibleobject.h +++ b/linden/indra/newview/llflexibleobject.h @@ -3,6 +3,8 @@ * @author JJ Ventrella, Andrew Meadows, Tom Yedwab * @brief Flexible object definition * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /** diff --git a/linden/indra/newview/llfloaterabout.cpp b/linden/indra/newview/llfloaterabout.cpp index b259455..460b719 100644 --- a/linden/indra/newview/llfloaterabout.cpp +++ b/linden/indra/newview/llfloaterabout.cpp @@ -3,6 +3,8 @@ * @author James Cook * @brief The about box from Help->About * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -93,10 +96,10 @@ LLFloaterAbout::LLFloaterAbout() LLViewerRegion* region = gAgent.getRegion(); if (region) { - //XUI:translate const LLVector3d &pos = gAgent.getPositionGlobal(); - LLString pos_text = llformat("You are at %.1f, %.1f, %.1f ", - pos.mdV[VX], pos.mdV[VY], pos.mdV[VZ]); + LLUIString pos_text = childGetText("you_are_at"); + pos_text.setArg("[POSITION]", + llformat("%.1f, %.1f, %.1f ", pos.mdV[VX], pos.mdV[VY], pos.mdV[VZ])); support.append(pos_text); LLString region_text = llformat("in %s located at ", @@ -114,6 +117,10 @@ LLFloaterAbout::LLFloaterAbout() support.append("\n\n"); } + //*NOTE: Do not translate text like GPU, Graphics Card, etc - + // Most PC users that know what these mean will be used to the english versions, + // and this info sometimes gets sent to support + // CPU support.append("CPU: "); support.append( gSysCPU.getCPUString() ); diff --git a/linden/indra/newview/llfloaterabout.h b/linden/indra/newview/llfloaterabout.h index 1e7ad4c..1ef4e76 100644 --- a/linden/indra/newview/llfloaterabout.h +++ b/linden/indra/newview/llfloaterabout.h @@ -2,6 +2,8 @@ * @file llfloaterabout.h * @brief The about box from Help -> About * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERABOUT_H diff --git a/linden/indra/newview/llfloateractivespeakers.cpp b/linden/indra/newview/llfloateractivespeakers.cpp index 1c3990e..fc9ab0e 100644 --- a/linden/indra/newview/llfloateractivespeakers.cpp +++ b/linden/indra/newview/llfloateractivespeakers.cpp @@ -2,6 +2,8 @@ * @file llfloateractivespeakers.cpp * @brief Management interface for muting and controlling volume of residents currently speaking * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -285,9 +288,9 @@ void LLPanelActiveSpeakers::refreshSpeakers() // } //} - row["columns"][0]["value"] = speakerp->mStatus == LLSpeaker::STATUS_MUTED ? + row["columns"][0]["value"] = (speakerp->mStatus == LLSpeaker::STATUS_MUTED) ? gViewerArt.getString("mute_icon.tga") : icon_image_id; - if (speakerp->mStatus > LLSpeaker::STATUS_VOICE_ACTIVE) // if voice is disabled for this speaker + if (speakerp->mStatus > LLSpeaker::STATUS_VOICE_ACTIVE && speakerp->mStatus != LLSpeaker::STATUS_MUTED) // if voice is disabled for this speaker { // non voice speakers have hidden icons, render as transparent row["columns"][0]["color"] = LLColor4(0.f, 0.f, 0.f, 0.f).getValue(); @@ -340,7 +343,6 @@ void LLPanelActiveSpeakers::refreshSpeakers() mMuteVoiceCtrl->setValue(gMuteListp->isMuted(selected_id, LLMute::flagVoiceChat)); mMuteVoiceCtrl->setEnabled(selected_id.notNull() && selected_id != gAgent.getID() - && mSpeakerMgr->isVoiceActive() && (speakerp.notNull() && speakerp->mType == LLSpeaker::SPEAKER_AGENT)); } if (mMuteTextCtrl) @@ -351,7 +353,6 @@ void LLPanelActiveSpeakers::refreshSpeakers() childSetValue("speaker_volume", gVoiceClient->getUserVolume(selected_id)); childSetEnabled("speaker_volume", selected_id.notNull() && selected_id != gAgent.getID() - && mSpeakerMgr->isVoiceActive() && (speakerp.notNull() && speakerp->mType == LLSpeaker::SPEAKER_AGENT)); if (mProfileBtn) { @@ -368,7 +369,7 @@ void LLPanelActiveSpeakers::refreshSpeakers() } else { - mNameText->setValue(""); + mNameText->setValue(LLString::null); } } diff --git a/linden/indra/newview/llfloateractivespeakers.h b/linden/indra/newview/llfloateractivespeakers.h index f24eca4..0c998d7 100644 --- a/linden/indra/newview/llfloateractivespeakers.h +++ b/linden/indra/newview/llfloateractivespeakers.h @@ -2,6 +2,8 @@ * @file llfloateractivespeakers.h * @brief Management interface for muting and controlling volume of residents currently speaking * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERACTIVESPEAKERS_H diff --git a/linden/indra/newview/llfloateranimpreview.cpp b/linden/indra/newview/llfloateranimpreview.cpp index 09fc508..71c2217 100644 --- a/linden/indra/newview/llfloateranimpreview.cpp +++ b/linden/indra/newview/llfloateranimpreview.cpp @@ -2,6 +2,8 @@ * @file llfloateranimpreview.cpp * @brief LLFloaterAnimPreview class implementation * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -291,8 +294,7 @@ BOOL LLFloaterAnimPreview::postBuild() delete mAnimPreview; mAnimPreview = NULL; mMotionID.setNull(); - // XUI:translate - childSetValue("bad_animation_text", LLSD("Failed to initialize motion.")); + childSetValue("bad_animation_text", childGetText("failed_to_initialize")); mEnabled = FALSE; } } @@ -302,18 +304,16 @@ BOOL LLFloaterAnimPreview::postBuild() { if (loaderp->getDuration() > MAX_ANIM_DURATION) { - char output_str[256]; /*Flawfinder: ignore*/ - - snprintf(output_str, sizeof(output_str), "Animation file is %.1f seconds in length.\n\nMaximum animation length is %.1f seconds.\n", /* Flawfinder: ignore */ - loaderp->getDuration(), MAX_ANIM_DURATION); - childSetValue("bad_animation_text", LLSD(output_str)); + LLUIString out_str = childGetText("anim_too_long"); + out_str.setArg("[LENGTH]", llformat("%.1f", loaderp->getDuration())); + out_str.setArg("[MAX_LENGTH]", llformat("%.1f", MAX_ANIM_DURATION)); + childSetValue("bad_animation_text", out_str.getString()); } else { - char* status = loaderp->getStatus(); - LLString error_string("Unable to read animation file.\n\n"); - error_string += LLString(status); - childSetValue("bad_animation_text", LLSD(error_string)); + LLUIString out_str = childGetText("failed_file_read"); + out_str.setArg("[STATUS]", loaderp->getStatus()); // *TODO:Translate + childSetValue("bad_animation_text", out_str.getString()); } } @@ -1155,3 +1155,4 @@ void LLPreviewAnimation::pan(F32 right, F32 up) mCameraOffset.mV[VZ] = llclamp(mCameraOffset.mV[VZ] + up * mCameraDistance / mCameraZoom, -1.f, 1.f); } + diff --git a/linden/indra/newview/llfloateranimpreview.h b/linden/indra/newview/llfloateranimpreview.h index 68cd3d5..e2383c5 100644 --- a/linden/indra/newview/llfloateranimpreview.h +++ b/linden/indra/newview/llfloateranimpreview.h @@ -2,6 +2,8 @@ * @file llfloateranimpreview.h * @brief LLFloaterAnimPreview class definition * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERANIMPREVIEW_H diff --git a/linden/indra/newview/llfloaterauction.cpp b/linden/indra/newview/llfloaterauction.cpp index e024bde..bc00565 100644 --- a/linden/indra/newview/llfloaterauction.cpp +++ b/linden/indra/newview/llfloaterauction.cpp @@ -3,6 +3,8 @@ * @author James Cook, Ian Wilkes * @brief Implementation of the auction floater. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -123,7 +126,7 @@ void LLFloaterAuction::initialize() } else { - childSetText("parcel_text", ""); + childSetText("parcel_text", LLString::null); } mParcelID = -1; childSetEnabled("snapshot_btn", false); diff --git a/linden/indra/newview/llfloaterauction.h b/linden/indra/newview/llfloaterauction.h index 51936bc..135c9fa 100644 --- a/linden/indra/newview/llfloaterauction.h +++ b/linden/indra/newview/llfloaterauction.h @@ -3,6 +3,8 @@ * @author James Cook, Ian Wilkes * @brief llfloaterauction class header file * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERAUCTION_H diff --git a/linden/indra/newview/llfloateravatarinfo.cpp b/linden/indra/newview/llfloateravatarinfo.cpp index c4b8167..c7341b6 100644 --- a/linden/indra/newview/llfloateravatarinfo.cpp +++ b/linden/indra/newview/llfloateravatarinfo.cpp @@ -2,6 +2,8 @@ * @file llfloateravatarinfo.cpp * @brief LLFloaterAvatarInfo class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /** @@ -51,6 +54,7 @@ #include "llbutton.h" #include "llcallingcard.h" #include "llcheckboxctrl.h" +#include "llcommandhandler.h" #include "llfloaterworldmap.h" #include "llfloatermute.h" #include "llinventoryview.h" @@ -75,18 +79,34 @@ const char FLOATER_TITLE[] = "Profile"; const LLRect FAI_RECT(0, 530, 420, 0); -const S32 RULER0 = 90; -const S32 RULER1 = RULER0 + 5; -const S32 RULER2 = RULER1 + 75; -const S32 RULER3 = RULER2 + 90; -const S32 RULER4 = RULER3 + 10; - //----------------------------------------------------------------------------- // Globals //----------------------------------------------------------------------------- LLMap< const LLUUID, LLFloaterAvatarInfo* > gAvatarInfoInstances; +class LLAgentHandler : public LLCommandHandler +{ +public: + LLAgentHandler() : LLCommandHandler("agent") { } + bool handle(const std::vector& params) + { + if (params.size() < 2) return false; + LLUUID agent_id; + if (!agent_id.set(params[0], FALSE)) + { + return false; + } + + if (params[1] == "about") + { + LLFloaterAvatarInfo::showFromDirectory(agent_id); + return true; + } + return false; + } +}; +LLAgentHandler gAgentHandler; //----------------------------------------------------------------------------- // Member functions diff --git a/linden/indra/newview/llfloateravatarinfo.h b/linden/indra/newview/llfloateravatarinfo.h index eedbfba..f305ae0 100644 --- a/linden/indra/newview/llfloateravatarinfo.h +++ b/linden/indra/newview/llfloateravatarinfo.h @@ -2,6 +2,8 @@ * @file llfloateravatarinfo.h * @brief LLFloaterAvatarInfo class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /** @@ -75,7 +78,7 @@ public: /*virtual*/ EAssetStatus getAssetStatus(); // Enables rate button, enables IM - static void showFromObject(const LLUUID &avatar_id, std::string tab_name = ""); + static void showFromObject(const LLUUID &avatar_id, std::string tab_name = std::string()); // Disables the rate button, enables IM static void showFromDirectory(const LLUUID &avatar_id); diff --git a/linden/indra/newview/llfloateravatarpicker.cpp b/linden/indra/newview/llfloateravatarpicker.cpp index 16c15b0..50f7387 100644 --- a/linden/indra/newview/llfloateravatarpicker.cpp +++ b/linden/indra/newview/llfloateravatarpicker.cpp @@ -1,6 +1,8 @@ /** * @file llfloateravatarpicker.cpp * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llfloateravatarpicker.h b/linden/indra/newview/llfloateravatarpicker.h index f9326ad..ace2d64 100644 --- a/linden/indra/newview/llfloateravatarpicker.h +++ b/linden/indra/newview/llfloateravatarpicker.h @@ -2,6 +2,8 @@ * @file llfloateravatarpicker.h * @brief was llavatarpicker.h * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLFLOATERAVATARPICKER_H diff --git a/linden/indra/newview/llfloateravatartextures.cpp b/linden/indra/newview/llfloateravatartextures.cpp index 5d53107..904f47d 100644 --- a/linden/indra/newview/llfloateravatartextures.cpp +++ b/linden/indra/newview/llfloateravatartextures.cpp @@ -2,6 +2,8 @@ * @file llfloateravatartextures.cpp * @brief Debugging view showing underlying avatar textures and baked textures. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llfloateravatartextures.h b/linden/indra/newview/llfloateravatartextures.h index bd67859..85208ce 100644 --- a/linden/indra/newview/llfloateravatartextures.h +++ b/linden/indra/newview/llfloateravatartextures.h @@ -2,6 +2,8 @@ * @file llfloateravatartextures.h * @brief Debugging view showing underlying avatar textures and baked textures. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERAVATARTEXTURES_H diff --git a/linden/indra/newview/llfloaterbuildoptions.cpp b/linden/indra/newview/llfloaterbuildoptions.cpp index 1bec048..5e4cc89 100644 --- a/linden/indra/newview/llfloaterbuildoptions.cpp +++ b/linden/indra/newview/llfloaterbuildoptions.cpp @@ -2,6 +2,8 @@ * @file llfloaterbuildoptions.cpp * @brief LLFloaterBuildOptions class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /** diff --git a/linden/indra/newview/llfloaterbuildoptions.h b/linden/indra/newview/llfloaterbuildoptions.h index a34aa2c..51e477a 100644 --- a/linden/indra/newview/llfloaterbuildoptions.h +++ b/linden/indra/newview/llfloaterbuildoptions.h @@ -2,6 +2,8 @@ * @file llfloaterbuildoptions.h * @brief LLFloaterBuildOptions class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /** diff --git a/linden/indra/newview/llfloaterbump.cpp b/linden/indra/newview/llfloaterbump.cpp index ee26d6a..e891bbe 100644 --- a/linden/indra/newview/llfloaterbump.cpp +++ b/linden/indra/newview/llfloaterbump.cpp @@ -3,6 +3,8 @@ * @brief Floater showing recent bumps, hits with objects, pushes, etc. * @author Cory Ondrejka, James Cook * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llfloaterbump.h b/linden/indra/newview/llfloaterbump.h index 476220a..e486058 100644 --- a/linden/indra/newview/llfloaterbump.h +++ b/linden/indra/newview/llfloaterbump.h @@ -3,6 +3,8 @@ * @brief Floater showing recent bumps, hits with objects, pushes, etc. * @author Cory Ondrejka, James Cook * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERBUMP_H diff --git a/linden/indra/newview/llfloaterbuy.cpp b/linden/indra/newview/llfloaterbuy.cpp index 4070ea7..707ec0e 100644 --- a/linden/indra/newview/llfloaterbuy.cpp +++ b/linden/indra/newview/llfloaterbuy.cpp @@ -3,6 +3,8 @@ * @author James Cook * @brief LLFloaterBuy class implementation * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /** @@ -110,21 +113,23 @@ void LLFloaterBuy::show(const LLSaleInfo& sale_info) sInstance->center(); LLSelectNode* node = selection->getFirstRootNode(); - if (!node) return; + if (!node) + return; // Set title based on sale type - std::ostringstream title; + LLUIString title; switch (sale_info.getSaleType()) { - case LLSaleInfo::FS_ORIGINAL: - title << "Buy " << node->mName; // XUI:translate + case LLSaleInfo::FS_ORIGINAL: + title = sInstance->childGetText("title_buy_text"); break; - case LLSaleInfo::FS_COPY: - default: - title << "Buy Copy of " << node->mName; // XUI:translate + case LLSaleInfo::FS_COPY: + default: + title = sInstance->childGetText("title_buy_copy_text"); break; } - sInstance->setTitle(title.str()); + title.setArg("[NAME]", node->mName); + sInstance->setTitle(title); LLUUID owner_id; LLString owner_name; @@ -160,15 +165,15 @@ void LLFloaterBuy::show(const LLSaleInfo& sale_info) LLString text = node->mName; if (!(next_owner_mask & PERM_COPY)) { - text.append(" (no copy)"); // XUI:translate + text.append(sInstance->childGetText("no_copy_text")); } if (!(next_owner_mask & PERM_MODIFY)) { - text.append(" (no modify)"); // XUI:translate + text.append(sInstance->childGetText("no_modify_text")); } if (!(next_owner_mask & PERM_TRANSFER)) { - text.append(" (no transfer)"); // XUI:translate + text.append(sInstance->childGetText("no_transfer_text")); } row["columns"][1]["column"] = "text"; diff --git a/linden/indra/newview/llfloaterbuy.h b/linden/indra/newview/llfloaterbuy.h index a4428fe..cdf79da 100644 --- a/linden/indra/newview/llfloaterbuy.h +++ b/linden/indra/newview/llfloaterbuy.h @@ -3,6 +3,8 @@ * @author James Cook * @brief LLFloaterBuy class definition * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /** diff --git a/linden/indra/newview/llfloaterbuycontents.cpp b/linden/indra/newview/llfloaterbuycontents.cpp index 7288b8d..3826679 100644 --- a/linden/indra/newview/llfloaterbuycontents.cpp +++ b/linden/indra/newview/llfloaterbuycontents.cpp @@ -3,6 +3,8 @@ * @author James Cook * @brief LLFloaterBuyContents class implementation * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /** @@ -235,20 +238,19 @@ void LLFloaterBuyContents::inventoryChanged(LLViewerObject* obj, U32 next_owner_mask = inv_item->getPermissions().getMaskNextOwner(); LLString text = (*it)->getName(); - // *TODO: Move into shared library function. if (!(next_owner_mask & PERM_COPY)) { - text.append(" (no copy)"); // XUI:translate + text.append(childGetText("no_copy_text")); } if (!(next_owner_mask & PERM_MODIFY)) { - text.append(" (no modify)"); // XUI:translate + text.append(childGetText("no_modify_text")); } if (!(next_owner_mask & PERM_TRANSFER)) { - text.append(" (no transfer)"); // XUI:translate + text.append(childGetText("no_transfer_text")); } - + row["columns"][1]["column"] = "text"; row["columns"][1]["value"] = text; row["columns"][1]["font"] = "SANSSERIF"; diff --git a/linden/indra/newview/llfloaterbuycontents.h b/linden/indra/newview/llfloaterbuycontents.h index 2553e09..8231174 100644 --- a/linden/indra/newview/llfloaterbuycontents.h +++ b/linden/indra/newview/llfloaterbuycontents.h @@ -3,6 +3,8 @@ * @author James Cook * @brief LLFloaterBuyContents class header file * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /** diff --git a/linden/indra/newview/llfloaterbuycurrency.cpp b/linden/indra/newview/llfloaterbuycurrency.cpp index 2ce46f7..a7233c3 100644 --- a/linden/indra/newview/llfloaterbuycurrency.cpp +++ b/linden/indra/newview/llfloaterbuycurrency.cpp @@ -2,6 +2,8 @@ * @file llfloaterbuycurrency.cpp * @brief LLFloaterBuyCurrency class implementation * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -313,7 +316,7 @@ void LLFloaterBuyCurrencyUI::onClickBuy(void* data) LLFloaterBuyCurrencyUI* self = LLFloaterBuyCurrencyUI::soleInstance(false); if (self) { - self->mManager.buy(); + self->mManager.buy(self->childGetText("buy_currency")); self->updateUI(); // JC: updateUI() doesn't get called again until progress is made // with transaction processing, so the "Purchase" button would be @@ -374,3 +377,4 @@ void LLFloaterBuyCurrency::buyCurrency(const std::string& name, S32 price) ui->open(); } + diff --git a/linden/indra/newview/llfloaterbuycurrency.h b/linden/indra/newview/llfloaterbuycurrency.h index 633a7b7..810cc97 100644 --- a/linden/indra/newview/llfloaterbuycurrency.h +++ b/linden/indra/newview/llfloaterbuycurrency.h @@ -2,6 +2,8 @@ * @file llfloaterbuycurrency.h * @brief LLFloaterBuyCurrency class definition * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERBUYCURRENCY_H diff --git a/linden/indra/newview/llfloaterbuyland.cpp b/linden/indra/newview/llfloaterbuyland.cpp index ed7f619..9ae634c 100644 --- a/linden/indra/newview/llfloaterbuyland.cpp +++ b/linden/indra/newview/llfloaterbuyland.cpp @@ -2,6 +2,8 @@ * @file llfloaterbuyland.cpp * @brief LLFloaterBuyLand class implementation * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -1019,9 +1022,9 @@ void LLFloaterBuyLandUI::refreshUI() } else { - childSetText("info_parcel", "(no parcel selected)"); - childSetText("info_size", ""); - childSetText("info_price", ""); + childSetText("info_parcel", childGetText("no_parcel_selected")); + childSetText("info_size", LLString::null); + childSetText("info_price", LLString::null); } childSetText("info_action", @@ -1124,7 +1127,7 @@ void LLFloaterBuyLandUI::refreshUI() if (mIsForGroup) { - childSetTextArg("insufficient_land_credits", "[GROUP]", gAgent.mGroupName); + childSetTextArg("insufficient_land_credits", "[GROUP]", LLString(gAgent.mGroupName)); message += childGetText("insufficient_land_credits"); @@ -1303,7 +1306,7 @@ void LLFloaterBuyLandUI::startBuyPreConfirm() } childSetTextArg("pay_to_for_land", "[AMOUNT]", llformat("%d", mParcelPrice)); - childSetTextArg("pay_to_for_land", "[SELLER]", mParcelSellerName.c_str()); + childSetTextArg("pay_to_for_land", "[SELLER]", mParcelSellerName); action += childGetText("pay_to_for_land"); @@ -1346,3 +1349,4 @@ void LLFloaterBuyLandUI::onClickErrorWeb(void* data) self->close(); } + diff --git a/linden/indra/newview/llfloaterbuyland.h b/linden/indra/newview/llfloaterbuyland.h index 328eaec..dd7cb39 100644 --- a/linden/indra/newview/llfloaterbuyland.h +++ b/linden/indra/newview/llfloaterbuyland.h @@ -2,6 +2,8 @@ * @file llfloaterbuyland.h * @brief LLFloaterBuyLand class definition * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERBUYLAND_H diff --git a/linden/indra/newview/llfloaterchat.cpp b/linden/indra/newview/llfloaterchat.cpp index 2621161..686cc81 100644 --- a/linden/indra/newview/llfloaterchat.cpp +++ b/linden/indra/newview/llfloaterchat.cpp @@ -2,6 +2,8 @@ * @file llfloaterchat.cpp * @brief LLFloaterChat class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /** diff --git a/linden/indra/newview/llfloaterchat.h b/linden/indra/newview/llfloaterchat.h index 9558a65..808393b 100644 --- a/linden/indra/newview/llfloaterchat.h +++ b/linden/indra/newview/llfloaterchat.h @@ -2,6 +2,8 @@ * @file llfloaterchat.h * @brief LLFloaterChat class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /* diff --git a/linden/indra/newview/llfloaterchatterbox.cpp b/linden/indra/newview/llfloaterchatterbox.cpp index 11d2ee6..bdd3090 100644 --- a/linden/indra/newview/llfloaterchatterbox.cpp +++ b/linden/indra/newview/llfloaterchatterbox.cpp @@ -4,7 +4,9 @@ * @date 2007-05-08 * @brief Implementation of the chatterbox integrated conversation ui * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ diff --git a/linden/indra/newview/llfloaterchatterbox.h b/linden/indra/newview/llfloaterchatterbox.h index 737f43e..3441093 100644 --- a/linden/indra/newview/llfloaterchatterbox.h +++ b/linden/indra/newview/llfloaterchatterbox.h @@ -4,7 +4,9 @@ * @date 2007-05-04 * @brief Integrated friends and group management/communication tool * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERCHATTERBOX_H diff --git a/linden/indra/newview/llfloaterclothing.cpp b/linden/indra/newview/llfloaterclothing.cpp index 8df90bc..fd3812c 100644 --- a/linden/indra/newview/llfloaterclothing.cpp +++ b/linden/indra/newview/llfloaterclothing.cpp @@ -3,6 +3,8 @@ * @author James Cook * @brief Read-only list of clothing from your inventory. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llfloaterclothing.h b/linden/indra/newview/llfloaterclothing.h index 6c2015a..9d824aa 100644 --- a/linden/indra/newview/llfloaterclothing.h +++ b/linden/indra/newview/llfloaterclothing.h @@ -2,6 +2,8 @@ * @file llfloaterclothing.h * @brief Read-only list of wearables from your inventory. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERCLOTHING_H diff --git a/linden/indra/newview/llfloatercolorpicker.cpp b/linden/indra/newview/llfloatercolorpicker.cpp index 973fe75..03e3a2e 100644 --- a/linden/indra/newview/llfloatercolorpicker.cpp +++ b/linden/indra/newview/llfloatercolorpicker.cpp @@ -2,6 +2,8 @@ * @file llfloatercolorpicker.cpp * @brief Generic system color picker * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -80,6 +83,7 @@ LLFloaterColorPicker (LLColorSwatchCtrl* swatch, BOOL show_apply_immediate ) mMouseDownInLumRegion ( FALSE ), mMouseDownInHueRegion ( FALSE ), mMouseDownInSwatch ( FALSE ), + // *TODO: Specify this in XML mRGBViewerImageLeft ( 140 ), mRGBViewerImageTop ( 356 ), mRGBViewerImageWidth ( 256 ), @@ -89,17 +93,19 @@ LLFloaterColorPicker (LLColorSwatchCtrl* swatch, BOOL show_apply_immediate ) mLumRegionWidth ( 16 ), mLumRegionHeight ( mRGBViewerImageHeight ), mLumMarkerSize ( 6 ), + // *TODO: Specify this in XML mSwatchRegionLeft ( 12 ), - mSwatchRegionTop ( 160 + 16 - 4 ), // get help text baseline to line up with bottom of RGB viewer - mSwatchRegionWidth ( 110 ), + mSwatchRegionTop ( 190 ), + mSwatchRegionWidth ( 116 ), mSwatchRegionHeight ( 60 ), mSwatchView ( NULL ), + // *TODO: Specify this in XML numPaletteColumns ( 16 ), numPaletteRows ( 2 ), highlightEntry ( -1 ), - mPaletteRegionLeft ( mSwatchRegionLeft - 1 ), + mPaletteRegionLeft ( 11 ), mPaletteRegionTop ( 100 - 8 ), - mPaletteRegionWidth ( mLumRegionLeft + mLumRegionWidth - mSwatchRegionLeft + 2 ), + mPaletteRegionWidth ( mLumRegionLeft + mLumRegionWidth - 10 ), mPaletteRegionHeight ( 40 ), mSwatch ( swatch ), mActive ( TRUE ), diff --git a/linden/indra/newview/llfloatercolorpicker.h b/linden/indra/newview/llfloatercolorpicker.h index 6c5fc85..abfe4c1 100644 --- a/linden/indra/newview/llfloatercolorpicker.h +++ b/linden/indra/newview/llfloatercolorpicker.h @@ -2,6 +2,8 @@ * @file llfloatercolorpicker.h * @brief Generic system color picker * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERCOLORPICKER_H diff --git a/linden/indra/newview/llfloatercustomize.cpp b/linden/indra/newview/llfloatercustomize.cpp index 3c5c9a5..5351aa5 100644 --- a/linden/indra/newview/llfloatercustomize.cpp +++ b/linden/indra/newview/llfloatercustomize.cpp @@ -2,6 +2,8 @@ * @file llfloatercustomize.cpp * @brief The customize avatar floater, triggered by "Appearance..." * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -74,7 +77,7 @@ #include "llfilepicker.h" -//XUI:translate : The ui xml for this really needs to be integrated with the appearance paramaters +//*TODO:translate : The ui xml for this really needs to be integrated with the appearance paramaters // Globals LLFloaterCustomize* gFloaterCustomize = NULL; @@ -866,8 +869,9 @@ void LLPanelEditWearable::draw() if(has_wearable && !is_modifiable) { + // *TODO:Translate childSetVisible("title_no_modify", TRUE); - childSetTextArg("title_no_modify", "[DESC]", LLWearable::typeToTypeLabel( mType )); + childSetTextArg("title_no_modify", "[DESC]", LLString(LLWearable::typeToTypeLabel( mType ))); for( std::map::iterator iter = mTextureList.begin(); iter != mTextureList.end(); ++iter ) @@ -882,8 +886,9 @@ void LLPanelEditWearable::draw() } else if(has_wearable && !is_complete) { + // *TODO:Translate childSetVisible("title_loading", TRUE); - childSetTextArg("title_loading", "[DESC]", LLWearable::typeToTypeLabel( mType )); + childSetTextArg("title_loading", "[DESC]", LLString(LLWearable::typeToTypeLabel( mType ))); LLString path; const LLUUID& item_id = gAgent.getWearableItem( wearable->getType() ); @@ -950,8 +955,9 @@ void LLPanelEditWearable::draw() } else { + // *TODO:Translate childSetVisible("title_not_worn", TRUE); - childSetTextArg("title_not_worn", "[DESC]", LLWearable::typeToTypeLabel( mType )); + childSetTextArg("title_not_worn", "[DESC]", LLString(LLWearable::typeToTypeLabel( mType ))); for( std::map::iterator iter = mTextureList.begin(); iter != mTextureList.end(); ++iter ) @@ -1184,7 +1190,7 @@ LLScrollingPanelParam::LLScrollingPanelParam( const LLString& name, childSetEnabled("param slider", mAllowModify); childSetCommitCallback("param slider", LLScrollingPanelParam::onSliderMoved, this); - // XUI:translate + // *TODO::translate LLString min_name = param->getMinDisplayName(); LLString max_name = param->getMaxDisplayName(); childSetValue("min param text", min_name); diff --git a/linden/indra/newview/llfloatercustomize.h b/linden/indra/newview/llfloatercustomize.h index a24dc39..fdaa1e5 100644 --- a/linden/indra/newview/llfloatercustomize.h +++ b/linden/indra/newview/llfloatercustomize.h @@ -2,6 +2,8 @@ * @file llfloatercustomize.h * @brief The customize avatar floater, triggered by "Appearance..." * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERCUSTOMIZE_H diff --git a/linden/indra/newview/llfloaterdirectory.cpp b/linden/indra/newview/llfloaterdirectory.cpp index 2e54166..1c06ed1 100644 --- a/linden/indra/newview/llfloaterdirectory.cpp +++ b/linden/indra/newview/llfloaterdirectory.cpp @@ -2,6 +2,8 @@ * @file llfloaterdirectory.cpp * @brief The "Find" floater. Should be llfloaterfind. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llfloaterdirectory.h b/linden/indra/newview/llfloaterdirectory.h index b57dc14..7314da7 100644 --- a/linden/indra/newview/llfloaterdirectory.h +++ b/linden/indra/newview/llfloaterdirectory.h @@ -2,6 +2,8 @@ * @file llfloaterdirectory.h * @brief The "Find" floater. Should be llfloaterfind. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERDIRECTORY_H diff --git a/linden/indra/newview/llfloatereditui.cpp b/linden/indra/newview/llfloatereditui.cpp index 47cf97d..a65ffc2 100644 --- a/linden/indra/newview/llfloatereditui.cpp +++ b/linden/indra/newview/llfloatereditui.cpp @@ -4,6 +4,8 @@ * @date May 2005 * @brief In-world user interface editor * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -233,7 +236,7 @@ void LLFloaterEditUI::refresh() if (!view) { mLastView = NULL; - mLabelLine->setText(""); + mLabelLine->setText(LLString::null); mLabelLine->setEnabled(FALSE); mWidthSpin->set(0.f); mWidthSpin->setEnabled(FALSE); @@ -302,7 +305,7 @@ void LLFloaterEditUI::refreshCore() void LLFloaterEditUI::refreshView(LLView* view) { mLabelLine->setEnabled(FALSE); - mLabelLine->setText(""); + mLabelLine->setText(LLString::null); childSetText("xml_name",view->getName()); } diff --git a/linden/indra/newview/llfloatereditui.h b/linden/indra/newview/llfloatereditui.h index 054339f..e1bf4d7 100644 --- a/linden/indra/newview/llfloatereditui.h +++ b/linden/indra/newview/llfloatereditui.h @@ -3,6 +3,8 @@ * @author James Cook * @brief In-world UI editor * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATEREDITUI_H diff --git a/linden/indra/newview/llfloaterfriends.cpp b/linden/indra/newview/llfloaterfriends.cpp index 67803e1..6f792e0 100644 --- a/linden/indra/newview/llfloaterfriends.cpp +++ b/linden/indra/newview/llfloaterfriends.cpp @@ -4,6 +4,8 @@ * @date 2005-01-13 * @brief Implementation of the friends floater * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ @@ -419,7 +422,7 @@ void LLPanelFriends::refreshUI() single_selected = TRUE; if(num_selected > 1) { - childSetText("friend_name_label", "Multiple friends..."); + childSetText("friend_name_label", childGetText("Multiple")); multiple_selected = TRUE; } else @@ -429,7 +432,7 @@ void LLPanelFriends::refreshUI() } else { - childSetText("friend_name_label", ""); + childSetText("friend_name_label", LLString::null); } diff --git a/linden/indra/newview/llfloaterfriends.h b/linden/indra/newview/llfloaterfriends.h index cf7451f..3d0b7a9 100644 --- a/linden/indra/newview/llfloaterfriends.h +++ b/linden/indra/newview/llfloaterfriends.h @@ -4,6 +4,8 @@ * @date 2005-01-13 * @brief Declaration of class for displaying the local agent's friends. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -26,6 +28,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERFRIENDS_H diff --git a/linden/indra/newview/llfloatergesture.cpp b/linden/indra/newview/llfloatergesture.cpp index 9746787..3bc7f5a 100644 --- a/linden/indra/newview/llfloatergesture.cpp +++ b/linden/indra/newview/llfloatergesture.cpp @@ -2,6 +2,8 @@ * @file llfloatergesture.cpp * @brief Read-only list of gestures from your inventory. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llfloatergesture.h b/linden/indra/newview/llfloatergesture.h index d463e09..08a96c4 100644 --- a/linden/indra/newview/llfloatergesture.h +++ b/linden/indra/newview/llfloatergesture.h @@ -2,6 +2,8 @@ * @file llfloatergesture.h * @brief Read-only list of gestures from your inventory. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /** diff --git a/linden/indra/newview/llfloatergodtools.cpp b/linden/indra/newview/llfloatergodtools.cpp index b858003..27d4271 100644 --- a/linden/indra/newview/llfloatergodtools.cpp +++ b/linden/indra/newview/llfloatergodtools.cpp @@ -2,6 +2,8 @@ * @file llfloatergodtools.cpp * @brief The on-screen rectangle with tool options. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -1257,8 +1260,8 @@ void LLPanelObjectTools::onClickSetBySelection(void* data) LLPanelObjectTools* panelp = (LLPanelObjectTools*) data; if (!panelp) return; - LLSelectNode* node = gSelectMgr->getSelection()->getFirstRootNode(); - if (!node) node = gSelectMgr->getSelection()->getFirstNode(); + const BOOL non_root_ok = TRUE; + LLSelectNode* node = gSelectMgr->getSelection()->getFirstRootNode(NULL, non_root_ok); if (!node) return; LLString owner_name; diff --git a/linden/indra/newview/llfloatergodtools.h b/linden/indra/newview/llfloatergodtools.h index 908ef63..53e250f 100644 --- a/linden/indra/newview/llfloatergodtools.h +++ b/linden/indra/newview/llfloatergodtools.h @@ -2,6 +2,8 @@ * @file llfloatergodtools.h * @brief The on-screen rectangle with tool options. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERGODTOOLS_H @@ -106,8 +109,6 @@ protected: LLFloaterGodTools(); ~LLFloaterGodTools(); - void setStatusText(const std::string& text); - // When the floater is going away, reset any options that need to be // cleared. void resetToolState(); diff --git a/linden/indra/newview/llfloatergroupinfo.cpp b/linden/indra/newview/llfloatergroupinfo.cpp index 6187692..3ddf968 100644 --- a/linden/indra/newview/llfloatergroupinfo.cpp +++ b/linden/indra/newview/llfloatergroupinfo.cpp @@ -2,6 +2,8 @@ * @file llfloatergroupinfo.cpp * @brief LLFloaterGroupInfo class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /** @@ -39,6 +42,7 @@ #include "llagent.h" #include "llcachename.h" +#include "llcommandhandler.h" #include "llpanelgroup.h" #include "llviewermessage.h" // for inventory_offer_callback @@ -51,6 +55,33 @@ const LLRect FGI_RECT(0, 530, 420, 0); // std::map LLFloaterGroupInfo::sInstances; +class LLGroupHandler : public LLCommandHandler +{ +public: + LLGroupHandler() : LLCommandHandler("group") { } + bool handle(const std::vector& tokens) + { + if (tokens.size() < 2) + { + return false; + } + + LLUUID group_id; + if (!group_id.set(tokens[0], FALSE)) + { + return false; + } + + if (tokens[1] == "about") + { + LLFloaterGroupInfo::showFromUUID(group_id); + return true; + } + return false; + } +}; +LLGroupHandler gGroupHandler; + //----------------------------------------------------------------------------- // Implementation //----------------------------------------------------------------------------- diff --git a/linden/indra/newview/llfloatergroupinfo.h b/linden/indra/newview/llfloatergroupinfo.h index b89fdc9..4e0bcd8 100644 --- a/linden/indra/newview/llfloatergroupinfo.h +++ b/linden/indra/newview/llfloatergroupinfo.h @@ -2,6 +2,8 @@ * @file llfloatergroupinfo.h * @brief LLFloaterGroupInfo class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /** @@ -49,7 +52,7 @@ public: static void showCreateGroup(void *); static void showMyGroupInfo(void *); static void showFromUUID(const LLUUID &group_id, - const std::string& tab_name = ""); + const std::string& tab_name = std::string()); static void closeCreateGroup(); static void closeGroup(const LLUUID& group_id); static void refreshGroup(const LLUUID& group_id); @@ -69,7 +72,7 @@ public: // if there is information that needs to be applied. virtual BOOL canClose(); protected: - LLFloaterGroupInfo(const std::string& name, const LLRect &rect, const std::string& title, const LLUUID& group_id = LLUUID::null, const std::string& tab_name = ""); + LLFloaterGroupInfo(const std::string& name, const LLRect &rect, const std::string& title, const LLUUID& group_id = LLUUID::null, const std::string& tab_name = std::string()); private: static void callbackLoadGroupName(const LLUUID& id, const char* first, const char* last, BOOL is_group, void* data); diff --git a/linden/indra/newview/llfloatergroupinvite.cpp b/linden/indra/newview/llfloatergroupinvite.cpp index 3ff95dc..6d76f76 100644 --- a/linden/indra/newview/llfloatergroupinvite.cpp +++ b/linden/indra/newview/llfloatergroupinvite.cpp @@ -2,6 +2,8 @@ * @file llfloatergroupinvite.cpp * @brief Floater to invite new members into a group. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llfloatergroupinvite.h b/linden/indra/newview/llfloatergroupinvite.h index 3ad0bf2..6b92f03 100644 --- a/linden/indra/newview/llfloatergroupinvite.h +++ b/linden/indra/newview/llfloatergroupinvite.h @@ -3,6 +3,8 @@ * @brief This floater is just a wrapper for LLPanelGroupInvite, which * is used to invite members to a specific group * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERGROUPINVITE_H diff --git a/linden/indra/newview/llfloatergroups.cpp b/linden/indra/newview/llfloatergroups.cpp index 5a442be..4573ca7 100644 --- a/linden/indra/newview/llfloatergroups.cpp +++ b/linden/indra/newview/llfloatergroups.cpp @@ -2,6 +2,8 @@ * @file llfloatergroups.cpp * @brief LLPanelGroups class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /* diff --git a/linden/indra/newview/llfloatergroups.h b/linden/indra/newview/llfloatergroups.h index 496a9fb..63b9096 100644 --- a/linden/indra/newview/llfloatergroups.h +++ b/linden/indra/newview/llfloatergroups.h @@ -2,6 +2,8 @@ * @file llfloatergroups.h * @brief LLFloaterGroups class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /* diff --git a/linden/indra/newview/llfloaterhtml.cpp b/linden/indra/newview/llfloaterhtml.cpp index 0c5bdcd..ebcf29f 100644 --- a/linden/indra/newview/llfloaterhtml.cpp +++ b/linden/indra/newview/llfloaterhtml.cpp @@ -2,6 +2,8 @@ * @file llfloaterhtml.cpp * @brief In-world HTML dialog * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,15 +26,19 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" +#include "llfloaterhtml.h" + +// viewer includes #include "llvieweruictrlfactory.h" -#include "llviewerwindow.h" #include "llviewercontrol.h" -#include "llfloaterhtml.h" -#include "llfloaterhtmlhelp.h" +#include "lllineeditor.h" + +#include "llwebbrowserctrl.h" LLFloaterHtml* LLFloaterHtml::sInstance = 0; @@ -59,6 +65,13 @@ LLFloaterHtml::LLFloaterHtml() // create floater from its XML definition gUICtrlFactory->buildFloater( this, "floater_html.xml" ); + childSetAction("back_btn", onClickBack, this); + childSetAction("home_btn", onClickHome, this); + childSetAction("forward_btn", onClickForward, this); + childSetAction("close_btn", onClickClose, this); + childSetCommitCallback("url_edit", onCommitUrlEdit, this ); + childSetAction("go_btn", onClickGo, this ); + // reposition floater from saved settings LLRect rect = gSavedSettings.getRect( "HtmlFloaterRect" ); reshape( rect.getWidth(), rect.getHeight(), FALSE ); @@ -68,32 +81,21 @@ LLFloaterHtml::LLFloaterHtml() mWebBrowser = LLViewerUICtrlFactory::getWebBrowserByName(this, "html_floater_browser" ); if ( mWebBrowser ) { - // observe browser events - mWebBrowser->addObserver( this ); - - // make links open in external browser - mWebBrowser->setOpenInExternalBrowser( true ); + // open links in internal browser + mWebBrowser->setOpenInExternalBrowser( false ); - // don't automatically open secondlife links since we want to catch - // special ones that do other stuff (like open F1 Help) - mWebBrowser->setOpenSecondLifeLinksInMap( false ); +// *FIX: code in merge sl-search-8 +// // don't automatically open secondlife links since we want to catch +// // special ones that do other stuff (like open F1 Help) +// mWebBrowser->setOpenSLURLsInMap( false ); } #endif // LL_LIBXUL_ENABLED - - childSetAction("close_btn", onClickClose, this); - setDefaultBtn("close_btn"); } //////////////////////////////////////////////////////////////////////////////// // LLFloaterHtml::~LLFloaterHtml() { -#if LL_LIBXUL_ENABLED - // stop observing browser events - if ( mWebBrowser ) - mWebBrowser->remObserver( this ); -#endif // LL_LIBXUL_ENABLED - // save position of floater gSavedSettings.setRect( "HtmlFloaterRect", mRect ); @@ -101,6 +103,25 @@ LLFloaterHtml::~LLFloaterHtml() } //////////////////////////////////////////////////////////////////////////////// +// virtual +void LLFloaterHtml::draw() +{ +#if LL_LIBXUL_ENABLED + // enable/disable buttons depending on state + if ( mWebBrowser ) + { + bool enable_back = mWebBrowser->canNavigateBack(); + childSetEnabled( "back_btn", enable_back ); + + bool enable_forward = mWebBrowser->canNavigateForward(); + childSetEnabled( "forward_btn", enable_forward ); + }; +#endif + + LLFloater::draw(); +} + +//////////////////////////////////////////////////////////////////////////////// // void LLFloaterHtml::show( LLString content_id ) { @@ -108,13 +129,22 @@ void LLFloaterHtml::show( LLString content_id ) LLString title_str = content_id + "_title"; LLString url_str = content_id + "_url"; + std::string title = childGetValue( title_str ).asString(); + std::string url = childGetValue( url_str ).asString(); + show( url, title ); +} + +//////////////////////////////////////////////////////////////////////////////// +// +void LLFloaterHtml::show( std::string start_url, std::string title ) +{ // set the title - setTitle( childGetValue( title_str ).asString() ); + setTitle( title ); #if LL_LIBXUL_ENABLED // navigate to the URL if ( mWebBrowser ) - mWebBrowser->navigateTo( childGetValue( url_str ).asString() ); + mWebBrowser->navigateTo( start_url ); #endif // LL_LIBXUL_ENABLED // make floater appear @@ -138,29 +168,95 @@ void LLFloaterHtml::onClickClose( void* data ) } //////////////////////////////////////////////////////////////////////////////// -// -void LLFloaterHtml::onClickLinkSecondLife( const EventType& eventIn ) +// static +void LLFloaterHtml::onClickBack( void* data ) { #if LL_LIBXUL_ENABLED - const std::string protocol( "secondlife://app." ); + LLFloaterHtml* self = ( LLFloaterHtml* )data; + if ( self ) + { + if ( self->mWebBrowser ) + { + self->mWebBrowser->navigateBack(); + }; + }; +#endif +} - // special 'app' secondlife link (using a different protocol - one that isn't registered in the browser) causes bad - // things to happen and Mozilla stops responding because it can't display the "invalid protocol dialog) - if ( LLString::compareInsensitive( eventIn.getStringValue().substr( 0, protocol.length() ).c_str(), protocol.c_str() ) == 0 ) +//////////////////////////////////////////////////////////////////////////////// +// +void LLFloaterHtml::onClickHome( void* data ) +{ + LLFloaterHtml* self = ( LLFloaterHtml* )data; + if ( self ) { - // extract the command string - LLString cmd = eventIn.getStringValue().substr( protocol.length() ); +#if LL_LIBXUL_ENABLED + if ( self->mWebBrowser ) + { + std::string home_url = self->childGetText("home_page_url"); + if ( home_url.length() > 4 ) + { + self->mWebBrowser->navigateTo( home_url ); + } + else + { + llwarns << "Invalid home page specified for HTML floater - navigating to default" << llendl; + self->mWebBrowser->navigateTo( "http://google.com" ); + } + }; +#endif + }; +} - // command is open the F1 Help floater - if ( LLString::compareInsensitive( cmd.c_str() , "floater.html.help" ) == 0 ) +//////////////////////////////////////////////////////////////////////////////// +// static +void LLFloaterHtml::onClickForward( void* data ) +{ + LLFloaterHtml* self = ( LLFloaterHtml* )data; + if ( self ) + { +#if LL_LIBXUL_ENABLED + if ( self->mWebBrowser ) { - gViewerHtmlHelp.show(); - } - } - else - // regular secondlife link - just open the map as normal + self->mWebBrowser->navigateForward(); + }; +#endif + }; +} + +//////////////////////////////////////////////////////////////////////////////// +// static +void LLFloaterHtml::onCommitUrlEdit(LLUICtrl* ctrl, void* user_data) +{ + LLFloaterHtml* self = (LLFloaterHtml*)user_data; + + LLLineEditor* editor = (LLLineEditor*)ctrl; + std::string url = editor->getText(); + +#if LL_LIBXUL_ENABLED + if ( self->mWebBrowser ) { - mWebBrowser->openMapAtlocation( eventIn.getStringValue() ); - } -#endif // LL_LIBXUL_ENABLED -}; + self->mWebBrowser->navigateTo( url ); + }; +#endif +} + +//////////////////////////////////////////////////////////////////////////////// +// static +void LLFloaterHtml::onClickGo( void* data ) +{ + LLFloaterHtml* self = ( LLFloaterHtml* )data; + if ( self ) + { + std::string url = self->childGetValue( "url_edit" ).asString(); + if ( url.length() ) + { +#if LL_LIBXUL_ENABLED + if ( self->mWebBrowser ) + { + self->mWebBrowser->navigateTo( url ); + }; +#endif + }; + }; +} diff --git a/linden/indra/newview/llfloaterhtml.h b/linden/indra/newview/llfloaterhtml.h index fef57d0..0e3b435 100644 --- a/linden/indra/newview/llfloaterhtml.h +++ b/linden/indra/newview/llfloaterhtml.h @@ -3,6 +3,8 @@ * @author James Cook * @brief In-world HTML dialog * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,29 +27,38 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERHTML_H #define LL_LLFLOATERHTML_H -#include "llwebbrowserctrl.h" #include "llfloater.h" +class LLWebBrowserCtrl; + class LLFloaterHtml : - public LLFloater, - public LLWebBrowserCtrlObserver + public LLFloater { public: static LLFloaterHtml* getInstance(); virtual ~LLFloaterHtml(); + virtual void draw(); virtual void onClose( bool app_quitting ); + // Pass string like "in-world_help" or "additional help" void show( LLString content_id ); - static void onClickClose( void* data ); - // observable browser events - virtual void onClickLinkSecondLife( const EventType& eventIn ); + // Pass raw URL and window title + void show( std::string start_url, std::string title ); + + static void onClickClose( void* data ); + static void onClickBack( void* data ); + static void onClickHome( void* data ); + static void onClickForward( void* data ); + static void onCommitUrlEdit(LLUICtrl* ctrl, void* user_data); + static void onClickGo( void* data ); private: LLFloaterHtml(); diff --git a/linden/indra/newview/llfloaterhtmlfind.cpp b/linden/indra/newview/llfloaterhtmlfind.cpp deleted file mode 100644 index 4aeea21..0000000 --- a/linden/indra/newview/llfloaterhtmlfind.cpp +++ /dev/null @@ -1,206 +0,0 @@ -/** - * @file llfloaterhtmlfind.cpp - * @brief HTML Find floater - uses embedded web browser control - * - * Copyright (c) 2006-2007, Linden Research, Inc. - * - * Second Life Viewer Source Code - * The source code in this file ("Source Code") is provided by Linden Lab - * to you under the terms of the GNU General Public License, version 2.0 - * ("GPL"), unless you have obtained a separate licensing agreement - * ("Other License"), formally executed by you and Linden Lab. Terms of - * the GPL can be found in doc/GPL-license.txt in this distribution, or - * online at http://secondlife.com/developers/opensource/gplv2 - * - * There are special exceptions to the terms and conditions of the GPL as - * it is applied to this Source Code. View the full text of the exception - * in the file doc/FLOSS-exception.txt in this software distribution, or - * online at http://secondlife.com/developers/opensource/flossexception - * - * By copying, modifying or distributing this software, you acknowledge - * that you have read and understood your obligations described above, - * and agree to abide by those obligations. - * - * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO - * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, - * COMPLETENESS OR PERFORMANCE. - */ - -#include "llviewerprecompiledheaders.h" - - -#include "llfloaterhtmlfind.h" - -#include "llvieweruictrlfactory.h" -#include "llbutton.h" -#include "llwebbrowserctrl.h" -#include "llviewerwindow.h" -#include "llviewercontrol.h" -#include "viewer.h" -#include "llfloaterworldmap.h" -#include "llfloater.h" - -#if LL_LIBXUL_ENABLED - -class LLFloaterHtmlFind : - public LLFloater, - public LLWebBrowserCtrlObserver -{ -public: - LLFloaterHtmlFind(); - virtual ~LLFloaterHtmlFind(); - - virtual BOOL postBuild(); - virtual void onClose( bool app_quitting ); - virtual void draw(); - - static void show( void* url_string = NULL ); - static void onClickClose( void* data ); - - static void onFocusGained( LLUICtrl* ctrl, void* data ); - - // embedded browser observables - virtual void onClickLinkHref( const EventType& eventIn ); - -protected: - LLWebBrowserCtrl* mWebBrowser; - static LLFloaterHtmlFind* sInstance; - LLButton* mCloseButton; -}; - -LLFloaterHtmlFind* LLFloaterHtmlFind::sInstance = 0; - -//////////////////////////////////////////////////////////////////////////////// -// -LLFloaterHtmlFind::LLFloaterHtmlFind() : - LLFloater( "HTML Find" ), - mWebBrowser( 0 ), - mCloseButton( 0 ) -{ - sInstance = this; -} - -//////////////////////////////////////////////////////////////////////////////// -// -LLFloaterHtmlFind::~LLFloaterHtmlFind() -{ - // stop observing browser events - if ( mWebBrowser ) - { - mWebBrowser->remObserver( this ); - }; - - // save position of floater - gSavedSettings.setRect( "HtmlFindRect", mRect ); - - sInstance = 0; -} - -//////////////////////////////////////////////////////////////////////////////// -// -BOOL LLFloaterHtmlFind::postBuild() -{ - mCloseButton = LLUICtrlFactory::getButtonByName(this, "close_btn" ); - if ( mCloseButton ) - { - mCloseButton->setClickedCallback( onClickClose ); - mCloseButton->setCallbackUserData( this ); - setDefaultBtn( mCloseButton ); - }; - - mWebBrowser = LLViewerUICtrlFactory::getWebBrowserByName(this, "html_find_browser" ); - - // // observe browser events - mWebBrowser->addObserver( this ); - - // browser built so navigate to the right page - LLString homePageUrl( "http://user.lindenlab.com/~callum/search.php" ); - mWebBrowser->navigateTo( homePageUrl ); - - return TRUE; -} - -//////////////////////////////////////////////////////////////////////////////// -// -void LLFloaterHtmlFind::draw() -{ - // just call the base class for now - more later - LLFloater::draw(); -} - -//////////////////////////////////////////////////////////////////////////////// -// -void LLFloaterHtmlFind::show( void* url_string ) -{ - if ( sInstance ) - { - sInstance->setVisibleAndFrontmost(); - return; - }; - - LLFloaterHtmlFind* self = new LLFloaterHtmlFind; - - // create floater from its XML definition - gUICtrlFactory->buildFloater( self, "floater_html_find.xml" ); - - // reposition floater from saved settings - LLRect rect = gSavedSettings.getRect( "HtmlFindRect" ); - self->reshape( rect.getWidth(), rect.getHeight(), FALSE ); - self->setRect( rect ); -} - -//////////////////////////////////////////////////////////////////////////////// -// -void LLFloaterHtmlFind::onClose( bool app_quitting ) -{ - setVisible( false ); -} - -//////////////////////////////////////////////////////////////////////////////// -// -void LLFloaterHtmlFind::onClickClose( void* data ) -{ - LLFloaterHtmlFind* self = ( LLFloaterHtmlFind* )data; - - self->setVisible( false ); -} - -//////////////////////////////////////////////////////////////////////////////// -// virtual (observer on enbedded browser) -void LLFloaterHtmlFind::onClickLinkHref( const EventType& eventIn ) -{ - #if !LL_RELEASE_FOR_DOWNLOAD - llinfos << "MOZ> onClickHref=" << eventIn.getStringValue() << llendl; - #endif - // if it was a secondlife:// address - if ( eventIn.getStringValue().substr( 0, std::string( "secondlife://" ).length() ) == "secondlife://" ) - { - // parse out sim name and coordinates - LLURLSimString::setString( eventIn.getStringValue() ); - LLURLSimString::parse(); - - // if there is a world map - if ( gFloaterWorldMap ) - { - #if !LL_RELEASE_FOR_DOWNLOAD - llinfos << "MOZ> sim name is [" << LLURLSimString::sInstance.mSimName.c_str() << "]" << llendl; - #endif - // mark where the destination is - gFloaterWorldMap->trackURL( LLURLSimString::sInstance.mSimName.c_str(), - LLURLSimString::sInstance.mX, - LLURLSimString::sInstance.mY, - LLURLSimString::sInstance.mZ ); - - // display map - LLFloaterWorldMap::show( NULL, TRUE ); - }; - }; -} - -// static -void LLHtmlFind::show(void* url_string) -{ - LLFloaterHtmlFind::show(url_string); -} - -#endif // LL_LIBXUL_ENABLED diff --git a/linden/indra/newview/llfloaterhtmlfind.h b/linden/indra/newview/llfloaterhtmlfind.h deleted file mode 100644 index 89f2138..0000000 --- a/linden/indra/newview/llfloaterhtmlfind.h +++ /dev/null @@ -1,42 +0,0 @@ -/** - * @file llfloaterhtmlfind.h - * @brief HTML Find floater - uses embedded web browser control - * - * Copyright (c) 2006-2007, Linden Research, Inc. - * - * Second Life Viewer Source Code - * The source code in this file ("Source Code") is provided by Linden Lab - * to you under the terms of the GNU General Public License, version 2.0 - * ("GPL"), unless you have obtained a separate licensing agreement - * ("Other License"), formally executed by you and Linden Lab. Terms of - * the GPL can be found in doc/GPL-license.txt in this distribution, or - * online at http://secondlife.com/developers/opensource/gplv2 - * - * There are special exceptions to the terms and conditions of the GPL as - * it is applied to this Source Code. View the full text of the exception - * in the file doc/FLOSS-exception.txt in this software distribution, or - * online at http://secondlife.com/developers/opensource/flossexception - * - * By copying, modifying or distributing this software, you acknowledge - * that you have read and understood your obligations described above, - * and agree to abide by those obligations. - * - * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO - * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, - * COMPLETENESS OR PERFORMANCE. - */ - -#if LL_LIBXUL_ENABLED - -#ifndef LL_LLFLOATERHTMLFIND_H -#define LL_LLFLOATERHTMLFIND_H - -class LLHtmlFind -{ -public: - static void show(void* url_string = NULL); -}; - -#endif // LL_LLFLOATERHTMLFIND_H - -#endif // LL_LIBXUL_ENABLED diff --git a/linden/indra/newview/llfloaterhtmlhelp.cpp b/linden/indra/newview/llfloaterhtmlhelp.cpp index 1d6f19e..10afce8 100644 --- a/linden/indra/newview/llfloaterhtmlhelp.cpp +++ b/linden/indra/newview/llfloaterhtmlhelp.cpp @@ -2,6 +2,8 @@ * @file llfloaterhtmlhelp.cpp * @brief HTML Help floater - uses embedded web browser control * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -213,6 +216,9 @@ void LLFloaterHtmlHelp::onClickF1HelpLoadURL(S32 option, void* userdata) else if ( lang == "pt" ) help_url = "http://help.secondlife.com/pt"; + else + if ( lang == "de" ) + help_url = "http://de.secondlife.com/support"; LLWeb::loadURL( help_url ); }; diff --git a/linden/indra/newview/llfloaterhtmlhelp.h b/linden/indra/newview/llfloaterhtmlhelp.h index 9e9c88d..c9a6d5b 100644 --- a/linden/indra/newview/llfloaterhtmlhelp.h +++ b/linden/indra/newview/llfloaterhtmlhelp.h @@ -2,6 +2,8 @@ * @file llfloaterhtmlhelp.h * @brief HTML Help floater - uses embedded web browser control * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #if LL_LIBXUL_ENABLED @@ -39,7 +42,7 @@ public: LLViewerHtmlHelp(); virtual ~LLViewerHtmlHelp(); - /*virtual*/ void show(std::string start_url = ""); + /*virtual*/ void show(std::string start_url = std::string()); /*virtual*/ BOOL getFloaterOpened(); }; diff --git a/linden/indra/newview/llfloaterimagepreview.cpp b/linden/indra/newview/llfloaterimagepreview.cpp index 554555d..c24d435 100644 --- a/linden/indra/newview/llfloaterimagepreview.cpp +++ b/linden/indra/newview/llfloaterimagepreview.cpp @@ -2,6 +2,8 @@ * @file llfloaterimagepreview.cpp * @brief LLFloaterImagePreview class implementation * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llfloaterimagepreview.h b/linden/indra/newview/llfloaterimagepreview.h index 1d212be..d90af9d 100644 --- a/linden/indra/newview/llfloaterimagepreview.h +++ b/linden/indra/newview/llfloaterimagepreview.h @@ -2,6 +2,8 @@ * @file llfloaterimagepreview.h * @brief LLFloaterImagePreview class definition * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERIMAGEPREVIEW_H diff --git a/linden/indra/newview/llfloaterimport.cpp b/linden/indra/newview/llfloaterimport.cpp index 7340c49..4923497 100644 --- a/linden/indra/newview/llfloaterimport.cpp +++ b/linden/indra/newview/llfloaterimport.cpp @@ -2,6 +2,8 @@ * @file llfloaterimport.cpp * @brief LLFloaterImport class implementation * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llfloaterimport.h b/linden/indra/newview/llfloaterimport.h index 9ac005f..d2a26bc 100644 --- a/linden/indra/newview/llfloaterimport.h +++ b/linden/indra/newview/llfloaterimport.h @@ -2,6 +2,8 @@ * @file llfloaterimport.h * @brief LLFloaterImport class definition * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // llfloaterimport.h diff --git a/linden/indra/newview/llfloaterinspect.cpp b/linden/indra/newview/llfloaterinspect.cpp index f494251..0ce91ef 100644 --- a/linden/indra/newview/llfloaterinspect.cpp +++ b/linden/indra/newview/llfloaterinspect.cpp @@ -2,6 +2,8 @@ * @file llfloaterinspect.cpp * @brief Floater for object inspection tool * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -94,27 +97,28 @@ void LLFloaterInspect::show(void* ignored) void LLFloaterInspect::onClickCreatorProfile(void* ctrl) { - if(sInstance->mObjectList->getAllSelected().size() == 0) return; + if(sInstance->mObjectList->getAllSelected().size() == 0) + { + return; + } LLScrollListItem* first_selected = sInstance->mObjectList->getFirstSelected(); if (first_selected) { - LLSelectNode* obj= sInstance->mObjectSelection->getFirstNode(); - LLUUID obj_id, creator_id; - obj_id = first_selected->getUUID(); - while(obj) + struct f : public LLSelectedNodeFunctor { - if(obj_id == obj->getObject()->getID()) + LLUUID obj_id; + f(const LLUUID& id) : obj_id(id) {} + virtual bool apply(LLSelectNode* node) { - creator_id = obj->mPermissions->getCreator(); - break; + return (obj_id == node->getObject()->getID()); } - obj = sInstance->mObjectSelection->getNextNode(); - } - if(obj) + } func(first_selected->getUUID()); + LLSelectNode* node = sInstance->mObjectSelection->getFirstNode(&func); + if(node) { - LLFloaterAvatarInfo::showFromDirectory(creator_id); + LLFloaterAvatarInfo::showFromDirectory(node->mPermissions->getCreator()); } } } @@ -127,20 +131,20 @@ void LLFloaterInspect::onClickOwnerProfile(void* ctrl) if (first_selected) { - LLSelectNode* obj= sInstance->mObjectSelection->getFirstNode(); - LLUUID obj_id, owner_id; - obj_id = first_selected->getUUID(); - while(obj) + LLUUID selected_id = first_selected->getUUID(); + struct f : public LLSelectedNodeFunctor { - if(obj_id == obj->getObject()->getID()) + LLUUID obj_id; + f(const LLUUID& id) : obj_id(id) {} + virtual bool apply(LLSelectNode* node) { - owner_id = obj->mPermissions->getOwner(); - break; + return (obj_id == node->getObject()->getID()); } - obj = sInstance->mObjectSelection->getNextNode(); - } - if(obj) + } func(selected_id); + LLSelectNode* node = sInstance->mObjectSelection->getFirstNode(&func); + if(node) { + const LLUUID& owner_id = node->mPermissions->getOwner(); LLFloaterAvatarInfo::showFromDirectory(owner_id); } } @@ -201,10 +205,12 @@ void LLFloaterInspect::refresh() } mObjectList->operateOnAll(LLScrollListCtrl::OP_DELETE); //List all transient objects, then all linked objects - LLSelectNode* obj = mObjectSelection->getFirstNode(); - LLSD row; - while(obj) + + for (LLObjectSelection::iterator iter = mObjectSelection->begin(); + iter != mObjectSelection->end(); iter++) { + LLSelectNode* obj = *iter; + LLSD row; char owner_first_name[MAX_STRING], owner_last_name[MAX_STRING]; char creator_first_name[MAX_STRING], creator_last_name[MAX_STRING]; char time[MAX_STRING]; @@ -240,7 +246,6 @@ void LLFloaterInspect::refresh() row["columns"][3]["type"] = "text"; row["columns"][3]["value"] = time; mObjectList->addElement(row, ADD_TOP); - obj = mObjectSelection->getNextNode(); } if(selected_index > -1 && mObjectList->getItemIndex(selected_uuid) == selected_index) { diff --git a/linden/indra/newview/llfloaterinspect.h b/linden/indra/newview/llfloaterinspect.h index ed4ebd1..8656f13 100644 --- a/linden/indra/newview/llfloaterinspect.h +++ b/linden/indra/newview/llfloaterinspect.h @@ -4,28 +4,31 @@ * @date 2006-12-16 * @brief Declaration of class for displaying object attributes * +* $LicenseInfo:firstyear=2006&license=viewergpl$ +* * Copyright (c) 2006-2007, Linden Research, Inc. * - * Second Life Viewer Source Code - * The source code in this file ("Source Code") is provided by Linden Lab - * to you under the terms of the GNU General Public License, version 2.0 - * ("GPL"), unless you have obtained a separate licensing agreement - * ("Other License"), formally executed by you and Linden Lab. Terms of - * the GPL can be found in doc/GPL-license.txt in this distribution, or - * online at http://secondlife.com/developers/opensource/gplv2 - * - * There are special exceptions to the terms and conditions of the GPL as - * it is applied to this Source Code. View the full text of the exception - * in the file doc/FLOSS-exception.txt in this software distribution, or - * online at http://secondlife.com/developers/opensource/flossexception - * - * By copying, modifying or distributing this software, you acknowledge - * that you have read and understood your obligations described above, - * and agree to abide by those obligations. - * - * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO - * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, - * COMPLETENESS OR PERFORMANCE. +* Second Life Viewer Source Code +* The source code in this file ("Source Code") is provided by Linden Lab +* to you under the terms of the GNU General Public License, version 2.0 +* ("GPL"), unless you have obtained a separate licensing agreement +* ("Other License"), formally executed by you and Linden Lab. Terms of +* the GPL can be found in doc/GPL-license.txt in this distribution, or +* online at http://secondlife.com/developers/opensource/gplv2 +* +* There are special exceptions to the terms and conditions of the GPL as +* it is applied to this Source Code. View the full text of the exception +* in the file doc/FLOSS-exception.txt in this software distribution, or +* online at http://secondlife.com/developers/opensource/flossexception +* +* By copying, modifying or distributing this software, you acknowledge +* that you have read and understood your obligations described above, +* and agree to abide by those obligations. +* +* ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO +* WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, +* COMPLETENESS OR PERFORMANCE. +* $/LicenseInfo$ */ #ifndef LL_LLFLOATERINSPECT_H diff --git a/linden/indra/newview/llfloaterlagmeter.cpp b/linden/indra/newview/llfloaterlagmeter.cpp new file mode 100644 index 0000000..399d0b6 --- /dev/null +++ b/linden/indra/newview/llfloaterlagmeter.cpp @@ -0,0 +1,365 @@ +/** + * @file llfloaterlagmeter.cpp + * @brief The "Lag-o-Meter" floater used to tell users what is causing lag. + * + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. + * + * Second Life Viewer Source Code + * The source code in this file ("Source Code") is provided by Linden Lab + * to you under the terms of the GNU General Public License, version 2.0 + * ("GPL"), unless you have obtained a separate licensing agreement + * ("Other License"), formally executed by you and Linden Lab. Terms of + * the GPL can be found in doc/GPL-license.txt in this distribution, or + * online at http://secondlife.com/developers/opensource/gplv2 + * + * There are special exceptions to the terms and conditions of the GPL as + * it is applied to this Source Code. View the full text of the exception + * in the file doc/FLOSS-exception.txt in this software distribution, or + * online at http://secondlife.com/developers/opensource/flossexception + * + * By copying, modifying or distributing this software, you acknowledge + * that you have read and understood your obligations described above, + * and agree to abide by those obligations. + * + * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO + * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, + * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ + */ + +#include "llviewerprecompiledheaders.h" + +#include "llfloaterlagmeter.h" + +#include "llvieweruictrlfactory.h" +#include "llviewerstats.h" +#include "llviewerimage.h" +#include "llviewercontrol.h" +#include "viewer.h" +#include "lltexturefetch.h" + +#include "llbutton.h" +#include "llfocusmgr.h" +#include "lltextbox.h" + +const LLString LAG_CRITICAL_IMAGE_NAME = "lag_status_critical.tga"; +const LLString LAG_WARNING_IMAGE_NAME = "lag_status_warning.tga"; +const LLString LAG_GOOD_IMAGE_NAME = "lag_status_good.tga"; + +LLFloaterLagMeter * LLFloaterLagMeter::sInstance = NULL; + +LLFloaterLagMeter::LLFloaterLagMeter() + : LLFloater("floater_lagmeter") +{ + gUICtrlFactory->buildFloater(this, "floater_lagmeter.xml"); + + // Don't let this window take keyboard focus -- it's confusing to + // lose arrow-key driving when testing lag. + setIsChrome(TRUE); + + mClientButton = LLUICtrlFactory::getButtonByName(this, "client_lagmeter"); + mClientText = LLUICtrlFactory::getTextBoxByName(this, "client_text"); + mClientCause = LLUICtrlFactory::getTextBoxByName(this, "client_lag_cause"); + + mNetworkButton = LLUICtrlFactory::getButtonByName(this, "network_lagmeter"); + mNetworkText = LLUICtrlFactory::getTextBoxByName(this, "network_text"); + mNetworkCause = LLUICtrlFactory::getTextBoxByName(this, "network_lag_cause"); + + mServerButton = LLUICtrlFactory::getButtonByName(this, "server_lagmeter"); + mServerText = LLUICtrlFactory::getTextBoxByName(this, "server_text"); + mServerCause = LLUICtrlFactory::getTextBoxByName(this, "server_lag_cause"); + + LLString config_string = childGetText("client_frame_rate_critical_fps"); + mClientFrameTimeCritical = 1.0f / (float)atof( config_string.c_str() ); + config_string = childGetText("client_frame_rate_warning_fps"); + mClientFrameTimeWarning = 1.0f / (float)atof( config_string.c_str() ); + + config_string = childGetText("network_packet_loss_critical_pct"); + mNetworkPacketLossCritical = (float)atof( config_string.c_str() ); + config_string = childGetText("network_packet_loss_warning_pct"); + mNetworkPacketLossWarning = (float)atof( config_string.c_str() ); + + config_string = childGetText("network_ping_critical_ms"); + mNetworkPingCritical = (float)atof( config_string.c_str() ); + config_string = childGetText("network_ping_warning_ms"); + mNetworkPingWarning = (float)atof( config_string.c_str() ); + config_string = childGetText("server_frame_rate_critical_fps"); + + mServerFrameTimeCritical = 1000.0f / (float)atof( config_string.c_str() ); + config_string = childGetText("server_frame_rate_warning_fps"); + mServerFrameTimeWarning = 1000.0f / (float)atof( config_string.c_str() ); + config_string = childGetText("server_single_process_max_time_ms"); + mServerSingleProcessMaxTime = (float)atof( config_string.c_str() ); + + mShrunk = false; + config_string = childGetText("max_width_px"); + mMaxWidth = atoi( config_string.c_str() ); + config_string = childGetText("min_width_px"); + mMinWidth = atoi( config_string.c_str() ); + + childSetTextArg("client_frame_time_critical_msg", "[CLIENT_FRAME_RATE_CRITICAL]", childGetText("client_frame_rate_critical_fps")); + childSetTextArg("client_frame_time_warning_msg", "[CLIENT_FRAME_RATE_CRITICAL]", childGetText("client_frame_rate_critical_fps")); + childSetTextArg("client_frame_time_warning_msg", "[CLIENT_FRAME_RATE_WARNING]", childGetText("client_frame_rate_warning_fps")); + + childSetTextArg("network_packet_loss_critical_msg", "[NETWORK_PACKET_LOSS_CRITICAL]", childGetText("network_packet_loss_critical_pct")); + childSetTextArg("network_packet_loss_warning_msg", "[NETWORK_PACKET_LOSS_CRITICAL]", childGetText("network_packet_loss_critical_pct")); + childSetTextArg("network_packet_loss_warning_msg", "[NETWORK_PACKET_LOSS_WARNING]", childGetText("network_packet_loss_warning_pct")); + + childSetTextArg("network_ping_critical_msg", "[NETWORK_PING_CRITICAL]", childGetText("network_ping_critical_ms")); + childSetTextArg("network_ping_warning_msg", "[NETWORK_PING_CRITICAL]", childGetText("network_ping_critical_ms")); + childSetTextArg("network_ping_warning_msg", "[NETWORK_PING_WARNING]", childGetText("network_ping_warning_ms")); + + childSetTextArg("server_frame_time_critical_msg", "[SERVER_FRAME_RATE_CRITICAL]", childGetText("server_frame_rate_critical_fps")); + childSetTextArg("server_frame_time_warning_msg", "[SERVER_FRAME_RATE_CRITICAL]", childGetText("server_frame_rate_critical_fps")); + childSetTextArg("server_frame_time_warning_msg", "[SERVER_FRAME_RATE_WARNING]", childGetText("server_frame_rate_warning_fps")); + + childSetAction("minimize", onClickShrink, this); + + // were we shrunk last time? + if (gSavedSettings.getBOOL("LagMeterShrunk")) + { + onClickShrink(this); + } +} + +LLFloaterLagMeter::~LLFloaterLagMeter() +{ + sInstance = NULL; + + // save shrunk status for next time + gSavedSettings.setBOOL("LagMeterShrunk", mShrunk); + // expand so we save the large window rectangle + if (mShrunk) + { + onClickShrink(this); + } +} + +void LLFloaterLagMeter::draw() +{ + determineClient(); + determineNetwork(); + determineServer(); + + LLFloater::draw(); +} + +//static +void LLFloaterLagMeter::show(void *data) +{ + if(!sInstance) sInstance = new LLFloaterLagMeter(); + sInstance->open(); +} + +void LLFloaterLagMeter::determineClient() +{ + F32 client_frame_time = gViewerStats->mFPSStat.getMeanDuration(); + bool find_cause = false; + + if (!gFocusMgr.getAppHasFocus()) + { + mClientButton->setImageUnselected(LAG_GOOD_IMAGE_NAME); + mClientText->setText( childGetText("client_frame_time_window_bg_msg") ); + mClientCause->setText( LLString::null ); + } + else if(client_frame_time >= mClientFrameTimeCritical) + { + mClientButton->setImageUnselected(LAG_CRITICAL_IMAGE_NAME); + mClientText->setText( childGetText("client_frame_time_critical_msg") ); + find_cause = true; + } + else if(client_frame_time >= mClientFrameTimeWarning) + { + mClientButton->setImageUnselected(LAG_WARNING_IMAGE_NAME); + mClientText->setText( childGetText("client_frame_time_warning_msg") ); + find_cause = true; + } + else + { + mClientButton->setImageUnselected(LAG_GOOD_IMAGE_NAME); + mClientText->setText( childGetText("client_frame_time_normal_msg") ); + mClientCause->setText( LLString::null ); + } + + if(find_cause) + { + if(gSavedSettings.getF32("RenderFarClip") > 128) + { + mClientCause->setText( childGetText("client_draw_distance_cause_msg") ); + } + else if(gTextureFetch->getNumRequests() > 2) + { + mClientCause->setText( childGetText("client_texture_loading_cause_msg") ); + } + else if(LLViewerImage::sBoundTextureMemory > LLViewerImage::sMaxBoundTextureMem) + { + mClientCause->setText( childGetText("client_texture_memory_cause_msg") ); + } + else + { + mClientCause->setText( childGetText("client_complex_objects_cause_msg") ); + } + } +} + +void LLFloaterLagMeter::determineNetwork() +{ + F32 packet_loss = gViewerStats->mPacketsLostPercentStat.getMean(); + F32 ping_time = gViewerStats->mSimPingStat.getMean(); + bool find_cause_loss = false; + bool find_cause_ping = false; + + if(packet_loss >= mNetworkPacketLossCritical) + { + mNetworkButton->setImageUnselected(LAG_CRITICAL_IMAGE_NAME); + mNetworkText->setText( childGetText("network_packet_loss_critical_msg") ); + find_cause_loss = true; + } + else if(ping_time >= mNetworkPingCritical) + { + mNetworkButton->setImageUnselected(LAG_CRITICAL_IMAGE_NAME); + mNetworkText->setText( childGetText("network_ping_critical_msg") ); + find_cause_ping = true; + } + else if(packet_loss >= mNetworkPacketLossWarning) + { + mNetworkButton->setImageUnselected(LAG_WARNING_IMAGE_NAME); + mNetworkText->setText( childGetText("network_packet_loss_warning_msg") ); + find_cause_loss = true; + } + else if(ping_time >= mNetworkPingWarning) + { + mNetworkButton->setImageUnselected(LAG_WARNING_IMAGE_NAME); + mNetworkText->setText( childGetText("network_ping_warning_msg") ); + find_cause_ping = true; + } + else + { + mNetworkButton->setImageUnselected(LAG_GOOD_IMAGE_NAME); + mNetworkText->setText( childGetText("network_performance_normal_msg") ); + } + + if(find_cause_loss) + { + mNetworkCause->setText( childGetText("network_packet_loss_cause_msg") ); + } + else if(find_cause_ping) + { + mNetworkCause->setText( childGetText("network_ping_cause_msg") ); + } + else + { + mNetworkCause->setText( LLString::null ); + } +} + +void LLFloaterLagMeter::determineServer() +{ + F32 sim_frame_time = gViewerStats->mSimFrameMsec.getCurrent(); + bool find_cause = false; + + if(sim_frame_time >= mServerFrameTimeCritical) + { + mServerButton->setImageUnselected(LAG_CRITICAL_IMAGE_NAME); + mServerText->setText( childGetText("server_frame_time_critical_msg") ); + find_cause = true; + } + else if(sim_frame_time >= mServerFrameTimeWarning) + { + mServerButton->setImageUnselected(LAG_WARNING_IMAGE_NAME); + mServerText->setText( childGetText("server_frame_time_warning_msg") ); + find_cause = true; + } + else + { + mServerButton->setImageUnselected(LAG_GOOD_IMAGE_NAME); + mServerText->setText( childGetText("server_frame_time_normal_msg") ); + mServerCause->setText( LLString::null ); + } + + if(find_cause) + { + if(gViewerStats->mSimSimPhysicsMsec.getCurrent() > mServerSingleProcessMaxTime) + { + mServerCause->setText( childGetText("server_physics_cause_msg") ); + } + else if(gViewerStats->mSimScriptMsec.getCurrent() > mServerSingleProcessMaxTime) + { + mServerCause->setText( childGetText("server_scripts_cause_msg") ); + } + else if(gViewerStats->mSimNetMsec.getCurrent() > mServerSingleProcessMaxTime) + { + mServerCause->setText( childGetText("server_net_cause_msg") ); + } + else if(gViewerStats->mSimAgentMsec.getCurrent() > mServerSingleProcessMaxTime) + { + mServerCause->setText( childGetText("server_agent_cause_msg") ); + } + else if(gViewerStats->mSimImagesMsec.getCurrent() > mServerSingleProcessMaxTime) + { + mServerCause->setText( childGetText("server_images_cause_msg") ); + } + else + { + mServerCause->setText( childGetText("server_generic_cause_msg") ); + } + } +} + +//static +void LLFloaterLagMeter::onClickShrink(void * data) +{ + LLFloaterLagMeter * self = (LLFloaterLagMeter*)data; + + LLButton * button = (LLButton*)self->getChildByName("minimize"); + S32 delta_width = self->mMaxWidth - self->mMinWidth; + LLRect r = self->getRect(); + if(self->mShrunk) + { + self->setTitle( self->childGetText("max_title_msg") ); + // make left edge appear to expand + r.translate(-delta_width, 0); + self->setRect(r); + self->reshape(self->mMaxWidth, self->getRect().getHeight()); + + self->childSetText("client", self->childGetText("client_text_msg") + ":"); + self->childSetText("network", self->childGetText("network_text_msg") + ":"); + self->childSetText("server", self->childGetText("server_text_msg") + ":"); + + // usually "<<" + button->setLabel( self->childGetText("smaller_label") ); + } + else + { + self->setTitle( self->childGetText("min_title_msg") ); + // make left edge appear to collapse + r.translate(delta_width, 0); + self->setRect(r); + self->reshape(self->mMinWidth, self->getRect().getHeight()); + + self->childSetText("client", self->childGetText("client_text_msg") ); + self->childSetText("network", self->childGetText("network_text_msg") ); + self->childSetText("server", self->childGetText("server_text_msg") ); + + // usually ">>" + button->setLabel( self->childGetText("bigger_label") ); + } + // Don't put keyboard focus on the button + button->setFocus(FALSE); + + self->mClientText->setVisible(self->mShrunk); + self->mClientCause->setVisible(self->mShrunk); + self->childSetVisible("client_help", self->mShrunk); + + self->mNetworkText->setVisible(self->mShrunk); + self->mNetworkCause->setVisible(self->mShrunk); + self->childSetVisible("network_help", self->mShrunk); + + self->mServerText->setVisible(self->mShrunk); + self->mServerCause->setVisible(self->mShrunk); + self->childSetVisible("server_help", self->mShrunk); + + self->mShrunk = !self->mShrunk; +} diff --git a/linden/indra/newview/llfloaterlagmeter.h b/linden/indra/newview/llfloaterlagmeter.h new file mode 100644 index 0000000..0309f19 --- /dev/null +++ b/linden/indra/newview/llfloaterlagmeter.h @@ -0,0 +1,80 @@ +/** + * @file llfloaterlagmeter.h + * @brief The "Lag-o-Meter" floater used to tell users what is causing lag. + * + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. + * + * Second Life Viewer Source Code + * The source code in this file ("Source Code") is provided by Linden Lab + * to you under the terms of the GNU General Public License, version 2.0 + * ("GPL"), unless you have obtained a separate licensing agreement + * ("Other License"), formally executed by you and Linden Lab. Terms of + * the GPL can be found in doc/GPL-license.txt in this distribution, or + * online at http://secondlife.com/developers/opensource/gplv2 + * + * There are special exceptions to the terms and conditions of the GPL as + * it is applied to this Source Code. View the full text of the exception + * in the file doc/FLOSS-exception.txt in this software distribution, or + * online at http://secondlife.com/developers/opensource/flossexception + * + * By copying, modifying or distributing this software, you acknowledge + * that you have read and understood your obligations described above, + * and agree to abide by those obligations. + * + * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO + * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, + * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ + */ + +#ifndef LLFLOATERLAGMETER_H +#define LLFLOATERLAGMETER_H + +#include "llfloater.h" + +class LLFloaterLagMeter : public LLFloater +{ +public: + /*virtual*/ void draw(); + static void show(void*); + +private: + LLFloaterLagMeter(); + /*virtual*/ ~LLFloaterLagMeter(); + + void determineClient(); + void determineNetwork(); + void determineServer(); + + static void onClickShrink(void * data); + + bool mShrunk; + S32 mMaxWidth, mMinWidth; + + F32 mClientFrameTimeCritical; + F32 mClientFrameTimeWarning; + LLButton * mClientButton; + LLTextBox * mClientText; + LLTextBox * mClientCause; + + F32 mNetworkPacketLossCritical; + F32 mNetworkPacketLossWarning; + F32 mNetworkPingCritical; + F32 mNetworkPingWarning; + LLButton * mNetworkButton; + LLTextBox * mNetworkText; + LLTextBox * mNetworkCause; + + F32 mServerFrameTimeCritical; + F32 mServerFrameTimeWarning; + F32 mServerSingleProcessMaxTime; + LLButton * mServerButton; + LLTextBox * mServerText; + LLTextBox * mServerCause; + + static LLFloaterLagMeter * sInstance; +}; + +#endif diff --git a/linden/indra/newview/llfloaterland.cpp b/linden/indra/newview/llfloaterland.cpp index a98c835..43c39aa 100644 --- a/linden/indra/newview/llfloaterland.cpp +++ b/linden/indra/newview/llfloaterland.cpp @@ -2,6 +2,8 @@ * @file llfloaterland.cpp * @brief "About Land" floater, allowing display and editing of land parcel properties. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,12 +26,12 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" #include -#include #include "llfloaterland.h" @@ -70,43 +72,10 @@ #include "llviewercontrol.h" #include "roles_constants.h" -static const S32 EDIT_HEIGHT = 16; -static const S32 LEFT = HPAD; -static const S32 BOTTOM = VPAD; -static const S32 RULER0 = LEFT; -static const S32 RULER05 = RULER0 + 24; -static const S32 RULER1 = RULER05 + 16; -static const S32 RULER15 = RULER1 + 20; -static const S32 RULER2 = RULER1 + 32; -static const S32 RULER205= RULER2 + 32; -static const S32 RULER20 = RULER2 + 64; -static const S32 RULER21 = RULER20 + 16; -static const S32 RULER22 = RULER21 + 32; -static const S32 RULER225 = RULER20 + 64; -static const S32 RULER23 = RULER22 + 64; -static const S32 RULER24 = RULER23 + 26; -static const S32 RULER3 = RULER2 + 102; -static const S32 RULER4 = RULER3 + 8; -static const S32 RULER5 = RULER4 + 50; -static const S32 RULER6 = RULER5 + 52; -static const S32 RULER7 = RULER6 + 24; -static const S32 RIGHT = LEFT + 278; -static const S32 FAR_RIGHT = LEFT + 324 + 40; - -static const char PRICE[] = "Price:"; -static const char NO_PRICE[] = ""; -static const char AREA[] = "Area:"; - static const char OWNER_ONLINE[] = "0"; static const char OWNER_OFFLINE[] = "1"; static const char OWNER_GROUP[] = "2"; -static const char NEED_TIER_TO_MODIFY_STRING[] = "You must approve your purchase to modify this land."; - -static const char WEB_PAGE[] = "Web page"; -static const char QUICKTIME_MOVIE[] = "QuickTime movie"; -static const char RAW_HTML[] = "Raw HTML"; - // constants used in callbacks below - syntactic sugar. static const BOOL BUY_GROUP_LAND = TRUE; static const BOOL BUY_PERSONAL_LAND = FALSE; @@ -387,7 +356,8 @@ BOOL LLPanelLandGeneral::postBuild() childSetUserData("Name", this); - mEditDesc = LLUICtrlFactory::getLineEditorByName(this, "Description"); + mEditDesc = LLUICtrlFactory::getTextEditorByName(this, "Description"); + mEditDesc->setCommitOnFocusLost(TRUE); mEditDesc->setCommitCallback(onCommitAny); childSetPrevalidate("Description", LLLineEditor::prevalidatePrintableNotPipe); childSetUserData("Description", this); @@ -505,12 +475,12 @@ void LLPanelLandGeneral::refresh() { // nothing selected, disable panel mEditName->setEnabled(FALSE); - mEditName->setText(""); + mEditName->setText(LLString::null); mEditDesc->setEnabled(FALSE); - mEditDesc->setText(""); + mEditDesc->setText(LLString::null); - mTextSalePending->setText(""); + mTextSalePending->setText(LLString::null); mTextSalePending->setEnabled(FALSE); mBtnDeedToGroup->setEnabled(FALSE); @@ -522,14 +492,13 @@ void LLPanelLandGeneral::refresh() mCheckContributeWithDeed->set(FALSE); mCheckContributeWithDeed->setEnabled(FALSE); - mTextOwner->setText(""); - mBtnProfile->setLabelSelected("Profile..."); - mBtnProfile->setLabelUnselected("Profile..."); + mTextOwner->setText(LLString::null); + mBtnProfile->setLabel(childGetText("profile_text")); mBtnProfile->setEnabled(FALSE); - mTextClaimDate->setText(""); - mTextGroup->setText(""); - mTextPrice->setText(""); + mTextClaimDate->setText(LLString::null); + mTextGroup->setText(LLString::null); + mTextPrice->setText(LLString::null); mSaleInfoForSale1->setVisible(FALSE); mSaleInfoForSale2->setVisible(FALSE); @@ -539,8 +508,8 @@ void LLPanelLandGeneral::refresh() mBtnSellLand->setVisible(FALSE); mBtnStopSellLand->setVisible(FALSE); - mTextPriceLabel->setText(NO_PRICE); - mTextDwell->setText(""); + mTextPriceLabel->setText(LLString::null); + mTextDwell->setText(LLString::null); mBtnBuyLand->setEnabled(FALSE); mBtnBuyGroupLand->setEnabled(FALSE); @@ -576,14 +545,14 @@ void LLPanelLandGeneral::refresh() // Is it owned? if (is_public) { - mTextSalePending->setText(""); + mTextSalePending->setText(LLString::null); mTextSalePending->setEnabled(FALSE); - mTextOwner->setText("(public)"); + mTextOwner->setText(childGetText("public_text")); mTextOwner->setEnabled(FALSE); mBtnProfile->setEnabled(FALSE); - mTextClaimDate->setText(""); + mTextClaimDate->setText(LLString::null); mTextClaimDate->setEnabled(FALSE); - mTextGroup->setText("(none)"); + mTextGroup->setText(childGetText("none_text")); mTextGroup->setEnabled(FALSE); mBtnStartAuction->setEnabled(FALSE); } @@ -591,20 +560,19 @@ void LLPanelLandGeneral::refresh() { if(!is_leased && (owner_id == gAgent.getID())) { - mTextSalePending->setText(NEED_TIER_TO_MODIFY_STRING); + mTextSalePending->setText(childGetText("need_tier_to_modify")); mTextSalePending->setEnabled(TRUE); } else if(parcel->getAuctionID()) { - char auction_str[MAX_STRING]; /*Flawfinder: ignore*/ - snprintf(auction_str, sizeof(auction_str), "Auction ID: %u", parcel->getAuctionID()); /* Flawfinder: ignore */ - mTextSalePending->setText(auction_str); + mTextSalePending->setText(childGetText("auction_id_text")); + mTextSalePending->setTextArg("[ID]", llformat("%u", parcel->getAuctionID())); mTextSalePending->setEnabled(TRUE); } else { // not the owner, or it is leased - mTextSalePending->setText(""); + mTextSalePending->setText(LLString::null); mTextSalePending->setEnabled(FALSE); } //refreshNames(); @@ -616,26 +584,25 @@ void LLPanelLandGeneral::refresh() if (parcel->getGroupID().isNull()) { // Not group owned, so "Profile" - mBtnProfile->setLabelSelected("Profile..."); - mBtnProfile->setLabelUnselected("Profile..."); + mBtnProfile->setLabel(childGetText("profile_text")); - mTextGroup->setText("(none)"); + mTextGroup->setText(childGetText("none_text")); mTextGroup->setEnabled(FALSE); } else { // Group owned, so "Info" - mBtnProfile->setLabelSelected("Info..."); - mBtnProfile->setLabelUnselected("Info..."); + mBtnProfile->setLabel(childGetText("info_text")); //mTextGroup->setText("HIPPOS!");//parcel->getGroupName()); mTextGroup->setEnabled(TRUE); } // Display claim date + // *TODO:Localize (Time format may need Translating) time_t claim_date = parcel->getClaimDate(); char time_buf[TIME_STR_LENGTH]; /*Flawfinder: ignore*/ - mTextClaimDate->setText(formatted_time(claim_date, time_buf)); + mTextClaimDate->setText(LLString(formatted_time(claim_date, time_buf))); mTextClaimDate->setEnabled(is_leased); BOOL enable_auction = (gAgent.getGodLevel() >= GOD_LIAISON) @@ -724,8 +691,6 @@ void LLPanelLandGeneral::refresh() gParcelMgr->canAgentBuyParcel(parcel, true)); // show pricing information - char price[64]; /*Flawfinder: ignore*/ - const char* label = NULL; S32 area; S32 claim_price; S32 rent_price; @@ -737,14 +702,12 @@ void LLPanelLandGeneral::refresh() &dwell); // Area - snprintf(price, sizeof(price), "%d sq. m.", area); /* Flawfinder: ignore */ - label = AREA; + LLUIString price = childGetText("area_size_text"); + price.setArg("[AREA]", llformat("%d",area)); + mTextPriceLabel->setText(childGetText("area_text")); + mTextPrice->setText(price.getString()); - mTextPriceLabel->setText(label); - mTextPrice->setText(price); - - snprintf(price, sizeof(price), "%.0f", dwell); /* Flawfinder: ignore */ - mTextDwell->setText(price); + mTextDwell->setText(llformat("%.0f", dwell)); if(region_owner) { @@ -772,15 +735,14 @@ void LLPanelLandGeneral::refreshNames() LLParcel *parcel = mParcel->getParcel(); if (!parcel) { - mTextOwner->setText(""); + mTextOwner->setText(LLString::null); return; } - char buffer[MAX_STRING]; /*Flawfinder: ignore*/ + LLString owner; if (parcel->getIsGroupOwned()) { - buffer[0] = '\0'; - strcat(buffer, "(Group Owned)"); /*Flawfinder: ignore*/ + owner = childGetText("group_owned_text"); } else { @@ -788,24 +750,23 @@ void LLPanelLandGeneral::refreshNames() char owner_first[MAX_STRING]; /*Flawfinder: ignore*/ char owner_last[MAX_STRING]; /*Flawfinder: ignore*/ gCacheName->getName(parcel->getOwnerID(), owner_first, owner_last); - snprintf(buffer, sizeof(buffer), "%s %s", owner_first, owner_last); /* Flawfinder: ignore */ + owner = llformat("%s %s", owner_first, owner_last); } if(LLParcel::OS_LEASE_PENDING == parcel->getOwnershipStatus()) { - strcat(buffer, " (Sale Pending)"); /*Flawfinder: ignore*/ + owner += childGetText("sale_pending_text"); } - mTextOwner->setText(buffer); + mTextOwner->setText(owner); + LLString group; if(!parcel->getGroupID().isNull()) { + char buffer[MAX_STRING]; /*Flawfinder: ignore*/ gCacheName->getGroupName(parcel->getGroupID(), buffer); + group = buffer; } - else - { - buffer[0] = '\0'; - } - mTextGroup->setText(buffer); + mTextGroup->setText(group); const LLUUID& auth_buyer_id = parcel->getAuthorizedBuyerID(); if(auth_buyer_id.notNull()) @@ -952,7 +913,7 @@ void LLPanelLandGeneral::onClickBuyPass(void* data) if (!parcel) return; S32 pass_price = parcel->getPassPrice(); - const char* parcel_name = parcel->getName(); + LLString parcel_name = parcel->getName(); F32 pass_hours = parcel->getPassHours(); char cost[256], time[256]; /*Flawfinder: ignore*/ @@ -1068,8 +1029,8 @@ BOOL LLPanelLandObjects::postBuild() { mFirstReply = TRUE; - mParcelObjectBonus = LLUICtrlFactory::getTextBoxByName(this, "Simulator Primitive Bonus Factor: 1.00"); - mSWTotalObjects = LLUICtrlFactory::getTextBoxByName(this, "0 out of 0 available"); + mParcelObjectBonus = LLUICtrlFactory::getTextBoxByName(this, "parcel_object_bonus"); + mSWTotalObjects = LLUICtrlFactory::getTextBoxByName(this, "objects_available"); mObjectContribution = LLUICtrlFactory::getTextBoxByName(this, "object_contrib_text"); mTotalObjects = LLUICtrlFactory::getTextBoxByName(this, "total_objects_text"); mOwnerObjects = LLUICtrlFactory::getTextBoxByName(this, "owner_objects_text"); @@ -1218,17 +1179,18 @@ void LLPanelLandObjects::refresh() if (!parcel) { - mSWTotalObjects->setText("0 out of 0 available"); - mObjectContribution->setText("0"); - mTotalObjects->setText("0"); - mOwnerObjects->setText("0"); - mGroupObjects->setText("0"); - mOtherObjects->setText("0"); - mSelectedObjects->setText("0"); + mSWTotalObjects->setTextArg("[COUNT]", llformat("%d", 0)); + mSWTotalObjects->setTextArg("[TOTAL]", llformat("%d", 0)); + mSWTotalObjects->setTextArg("[AVAILABLE]", llformat("%d", 0)); + mObjectContribution->setTextArg("[COUNT]", llformat("%d", 0)); + mTotalObjects->setTextArg("[COUNT]", llformat("%d", 0)); + mOwnerObjects->setTextArg("[COUNT]", llformat("%d", 0)); + mGroupObjects->setTextArg("[COUNT]", llformat("%d", 0)); + mOtherObjects->setTextArg("[COUNT]", llformat("%d", 0)); + mSelectedObjects->setTextArg("[COUNT]", llformat("%d", 0)); } else { - char count[MAX_STRING]; /*Flawfinder: ignore*/ S32 sw_max = 0; S32 sw_total = 0; S32 max = 0; @@ -1255,47 +1217,34 @@ void LLPanelLandObjects::refresh() if (parcel_object_bonus != 1.0f) { - snprintf(count, sizeof(count), "Region Object Bonus Factor: %.2f", /* Flawfinder: ignore */ - parcel_object_bonus); - mParcelObjectBonus->setText(count); + mParcelObjectBonus->setVisible(TRUE); + mParcelObjectBonus->setTextArg("[BONUS]", llformat("%.2f", parcel_object_bonus)); } else { - mParcelObjectBonus->setText(""); + mParcelObjectBonus->setVisible(FALSE); } if (sw_total > sw_max) { - snprintf(count, sizeof(count), "%d out of %d (%d will be deleted)", /* Flawfinder: ignore */ - sw_total, sw_max, sw_total - sw_max); + mSWTotalObjects->setText(childGetText("objects_deleted_text")); + mSWTotalObjects->setTextArg("[DELETED]", llformat("%d", sw_total - sw_max)); } else { - snprintf(count, sizeof(count), "%d out of %d (%d available)", /* Flawfinder: ignore */ - sw_total, sw_max, sw_max - sw_total); + mSWTotalObjects->setText(childGetText("objects_available_text")); + mSWTotalObjects->setTextArg("[AVAILABLE]", llformat("%d", sw_max - sw_total)); } - mSWTotalObjects->setText(count); - - snprintf(count, sizeof(count), "%d", max); /* Flawfinder: ignore */ - mObjectContribution->setText(count); - - snprintf(count, sizeof(count), "%d", total); /* Flawfinder: ignore */ - mTotalObjects->setText(count); - - snprintf(count, sizeof(count), "%d", owned); /* Flawfinder: ignore */ - mOwnerObjects->setText(count); - - snprintf(count, sizeof(count), "%d", group); /* Flawfinder: ignore */ - mGroupObjects->setText(count); - - snprintf(count, sizeof(count), "%d", other); /* Flawfinder: ignore */ - mOtherObjects->setText(count); - - snprintf(count, sizeof(count), "%d", selected); /* Flawfinder: ignore */ - mSelectedObjects->setText(count); + mSWTotalObjects->setTextArg("[COUNT]", llformat("%d", sw_total)); + mSWTotalObjects->setTextArg("[MAX]", llformat("%d", sw_max)); - snprintf(count, sizeof(count), "%d", mOtherTime); /* Flawfinder: ignore */ - mCleanOtherObjectsTime->setText(count); + mObjectContribution->setTextArg("[COUNT]", llformat("%d", max)); + mTotalObjects->setTextArg("[COUNT]", llformat("%d", total)); + mOwnerObjects->setTextArg("[COUNT]", llformat("%d", owned)); + mGroupObjects->setTextArg("[COUNT]", llformat("%d", group)); + mOtherObjects->setTextArg("[COUNT]", llformat("%d", other)); + mSelectedObjects->setTextArg("[COUNT]", llformat("%d", selected)); + mCleanOtherObjectsTime->setText(llformat("%d", mOtherTime)); BOOL can_return_owned = LLViewerParcelMgr::isParcelModifiableByAgent(parcel, GP_LAND_RETURN_GROUP_OWNED); BOOL can_return_group_set = LLViewerParcelMgr::isParcelModifiableByAgent(parcel, GP_LAND_RETURN_GROUP_SET); @@ -1485,7 +1434,6 @@ void LLPanelLandObjects::callbackReturnOwnerList(S32 option, void* userdata) } else { - // XUI:translate NAME -> FIRST LAST args["[NAME]"] = self->mSelectedName; LLNotifyBox::showXml("OtherObjectsReturned2", args); } @@ -1630,7 +1578,7 @@ void LLPanelLandObjects::processParcelObjectOwnersReply(LLMessageSystem *msg, vo row->addColumn(OWNER_OFFLINE, FONT, self->mColWidth[1]); } // Placeholder for name. - row->addColumn("", FONT, self->mColWidth[2]); + row->addColumn(LLString::null, FONT, self->mColWidth[2]); snprintf(object_count_str, sizeof(object_count_str), "%d", object_count); /* Flawfinder: ignore */ row->addColumn(object_count_str, FONT, self->mColWidth[3]); @@ -1977,10 +1925,6 @@ BOOL LLPanelLandOptions::postBuild() mCategoryCombo = LLUICtrlFactory::getComboBoxByName(this, "land category"); childSetCommitCallback("land category", onCommitAny, this); - mAllowPublishCtrl = LLUICtrlFactory::getCheckBoxByName(this, "PublishCheck"); - childSetCommitCallback("PublishCheck", onCommitAny, this); - - mMatureCtrl = LLUICtrlFactory::getCheckBoxByName(this, "MatureCheck"); childSetCommitCallback("MatureCheck", onCommitAny, this); @@ -1991,8 +1935,6 @@ BOOL LLPanelLandOptions::postBuild() if (gAgent.mAccess < SIM_ACCESS_MATURE) { // Disable these buttons if they are PG (Teen) users - mAllowPublishCtrl->setVisible(FALSE); - mAllowPublishCtrl->setEnabled(FALSE); mPublishHelpButton->setVisible(FALSE); mPublishHelpButton->setEnabled(FALSE); mMatureCtrl->setVisible(FALSE); @@ -2035,7 +1977,7 @@ BOOL LLPanelLandOptions::postBuild() } - mLocationText = LLUICtrlFactory::getTextBoxByName(this, "Landing Point: (none)"); + mLocationText = LLUICtrlFactory::getTextBoxByName(this, "landing_point"); mSetBtn = LLUICtrlFactory::getButtonByName(this, "Set"); mSetBtn->setClickedCallback(onClickSet, this); @@ -2100,8 +2042,9 @@ void LLPanelLandOptions::refresh() mPushRestrictionCtrl->set(FALSE); mPushRestrictionCtrl->setEnabled(FALSE); + // *TODO:Translate const char* none_string = LLParcel::getCategoryUIString(LLParcel::C_NONE); - mCategoryCombo->setSimple(none_string); + mCategoryCombo->setSimple(LLString(none_string)); mCategoryCombo->setEnabled(FALSE); mLandingTypeCombo->setCurrentByIndex(0); @@ -2110,11 +2053,10 @@ void LLPanelLandOptions::refresh() mSnapshotCtrl->setImageAssetID(LLUUID::null); mSnapshotCtrl->setEnabled(FALSE); - mLocationText->setText("Landing Point: (none)"); + mLocationText->setTextArg("[LANDING]", childGetText("landing_point_none")); mSetBtn->setEnabled(FALSE); mClearBtn->setEnabled(FALSE); - mAllowPublishCtrl->setEnabled(FALSE); mMatureCtrl->setEnabled(FALSE); mPublishHelpButton->setEnabled(FALSE); } @@ -2155,29 +2097,26 @@ void LLPanelLandOptions::refresh() mCheckOtherScripts ->set( parcel->getAllowOtherScripts() ); mCheckOtherScripts ->setEnabled( can_change_options ); - BOOL can_change_identity = LLViewerParcelMgr::isParcelModifiableByAgent(parcel, - GP_LAND_CHANGE_IDENTITY); - mCheckShowDirectory ->set( parcel->getParcelFlag(PF_SHOW_DIRECTORY)); - mCheckShowDirectory ->setEnabled( can_change_identity ); - mPushRestrictionCtrl->set( parcel->getRestrictPushObject() ); if(parcel->getRegionPushOverride()) { - mPushRestrictionCtrl->setLabel("Restrict Pushing (Region Override)"); + mPushRestrictionCtrl->setLabel(childGetText("push_restrict_region_text")); mPushRestrictionCtrl->setEnabled(false); mPushRestrictionCtrl->set(TRUE); } else { - mPushRestrictionCtrl->setLabel("Restrict Pushing"); + mPushRestrictionCtrl->setLabel(childGetText("push_restrict_text")); mPushRestrictionCtrl->setEnabled(can_change_options); } - // Set by string in case the order in UI doesn't match the order - // by index. + BOOL can_change_identity = + LLViewerParcelMgr::isParcelModifiableByAgent(parcel, GP_LAND_CHANGE_IDENTITY); + // Set by string in case the order in UI doesn't match the order by index. + // *TODO:Translate LLParcel::ECategory cat = parcel->getCategory(); const char* category_string = LLParcel::getCategoryUIString(cat); - mCategoryCombo->setSimple(category_string); + mCategoryCombo->setSimple(LLString(category_string)); mCategoryCombo->setEnabled( can_change_identity ); BOOL can_change_landing_point = LLViewerParcelMgr::isParcelModifiableByAgent(parcel, @@ -2191,23 +2130,19 @@ void LLPanelLandOptions::refresh() LLVector3 pos = parcel->getUserLocation(); if (pos.isExactlyZero()) { - mLocationText->setText("Landing Point: (none)"); + mLocationText->setTextArg("[LANDING]", childGetText("landing_point_none")); } else { - char buffer[256]; /*Flawfinder: ignore*/ - snprintf(buffer, sizeof(buffer), "Landing Point: %d, %d, %d", /* Flawfinder: ignore */ - llround(pos.mV[VX]), - llround(pos.mV[VY]), - llround(pos.mV[VZ])); - mLocationText->setText(buffer); + mLocationText->setTextArg("[LANDING]",llformat("%d, %d, %d", + llround(pos.mV[VX]), + llround(pos.mV[VY]), + llround(pos.mV[VZ]))); } mSetBtn->setEnabled( can_change_landing_point ); mClearBtn->setEnabled( can_change_landing_point ); - mAllowPublishCtrl->set(parcel->getAllowPublish()); - mAllowPublishCtrl->setEnabled( can_change_identity ); mMatureCtrl->set(parcel->getMaturePublish()); mMatureCtrl->setEnabled( can_change_identity ); mPublishHelpButton->setEnabled( can_change_identity ); @@ -2215,8 +2150,6 @@ void LLPanelLandOptions::refresh() if (gAgent.mAccess < SIM_ACCESS_MATURE) { // Disable these buttons if they are PG (Teen) users - mAllowPublishCtrl->setVisible(FALSE); - mAllowPublishCtrl->setEnabled(FALSE); mPublishHelpButton->setVisible(FALSE); mPublishHelpButton->setEnabled(FALSE); mMatureCtrl->setVisible(FALSE); @@ -2225,7 +2158,39 @@ void LLPanelLandOptions::refresh() } } +// virtual +void LLPanelLandOptions::draw() +{ + LLParcel *parcel = gParcelMgr->getFloatingParcelSelection()->getParcel(); + + if(parcel) + { + LLViewerRegion* region; + region = gParcelMgr->getSelectionRegion(); + llassert(region); // Region should never be null. + + BOOL can_change_identity = region ? + LLViewerParcelMgr::isParcelModifiableByAgent(parcel, GP_LAND_CHANGE_IDENTITY) && + ! (region->getRegionFlags() & REGION_FLAGS_BLOCK_PARCEL_SEARCH) : false; + + // There is a bug with this panel whereby the Show Directory bit can be + // slammed off by the Region based on an override. Since this data is cached + // locally the change will not reflect in the panel, which could cause confusion + // A workaround for this is to flip the bit off in the locally cached version + // when we detect a mismatch case. + if(! can_change_identity && parcel->getParcelFlag(PF_SHOW_DIRECTORY)) + { + parcel->setParcelFlag(PF_SHOW_DIRECTORY, FALSE); + } + mCheckShowDirectory ->set(parcel->getParcelFlag(PF_SHOW_DIRECTORY)); + mCheckShowDirectory ->setEnabled(can_change_identity); + mCategoryCombo->setEnabled(can_change_identity); + } + + LLPanel::draw(); + +} // static void LLPanelLandOptions::onCommitAny(LLUICtrl *ctrl, void *userdata) { @@ -2248,7 +2213,7 @@ void LLPanelLandOptions::onCommitAny(LLUICtrl *ctrl, void *userdata) BOOL allow_landmark = self->mCheckLandmark->get(); BOOL allow_group_scripts = self->mCheckGroupScripts->get() || self->mCheckOtherScripts->get(); BOOL allow_other_scripts = self->mCheckOtherScripts->get(); - BOOL allow_publish = self->mAllowPublishCtrl->get(); + BOOL allow_publish = FALSE; BOOL mature_publish = self->mMatureCtrl->get(); BOOL push_restriction = self->mPushRestrictionCtrl->get(); BOOL show_directory = self->mCheckShowDirectory->get(); @@ -2338,7 +2303,22 @@ void LLPanelLandOptions::onClickClear(void* userdata) // static void LLPanelLandOptions::onClickPublishHelp(void*) { - gViewerWindow->alertXml("ClickPublishHelpLand"); + LLViewerRegion* region = gParcelMgr->getSelectionRegion(); + LLParcel *parcel = gParcelMgr->getFloatingParcelSelection()->getParcel(); + llassert(region); // Region should never be null. + + bool can_change_identity = region && parcel ? + LLViewerParcelMgr::isParcelModifiableByAgent(parcel, GP_LAND_CHANGE_IDENTITY) && + ! (region->getRegionFlags() & REGION_FLAGS_BLOCK_PARCEL_SEARCH) : false; + + if(! can_change_identity) + { + gViewerWindow->alertXml("ClickPublishHelpLandDisabled"); + } + else + { + gViewerWindow->alertXml("ClickPublishHelpLand"); + } } //--------------------------------------------------------------------------- @@ -2408,10 +2388,10 @@ void LLPanelLandMedia::refresh() mRadioVoiceChat->setSelectedIndex(kRadioVoiceChatEstate); mRadioVoiceChat->setEnabled(FALSE); - mMusicURLEdit->setText(""); + mMusicURLEdit->setText(LLString::null); mMusicURLEdit->setEnabled(FALSE); - mMediaURLEdit->setText(""); + mMediaURLEdit->setText(LLString::null); mMediaURLEdit->setEnabled(FALSE); mMediaAutoScaleCheck->set ( FALSE ); @@ -2627,24 +2607,20 @@ void LLPanelLandAccess::refresh() if (parcel) { - char label[256]; /*Flawfinder: ignore*/ - // Display options BOOL use_group = parcel->getParcelFlag(PF_USE_ACCESS_GROUP); mCheckGroup->set( use_group ); char group_name[MAX_STRING]; /*Flawfinder: ignore*/ gCacheName->getGroupName(parcel->getGroupID(), group_name); - snprintf(label, sizeof(label), "Group: %s", group_name); /* Flawfinder: ignore */ - mCheckGroup->setLabel( label ); + mCheckGroup->setLabelArg( "[GROUP]", LLString(group_name) ); S32 count = parcel->mAccessList.size(); BOOL use_list = parcel->getParcelFlag(PF_USE_ACCESS_LIST); mCheckAccess->set( use_list ); - snprintf(label, sizeof(label), "Avatars: (%d listed, %d max)", /* Flawfinder: ignore */ - count, PARCEL_MAX_ACCESS_LIST); - mCheckAccess->setLabel( label ); + mCheckAccess->setLabelArg( "[LISTED]", llformat("%d",count)); + mCheckAccess->setLabelArg( "[MAX]", llformat("%d",PARCEL_MAX_ACCESS_LIST)); access_map_const_iterator cit = parcel->mAccessList.begin(); access_map_const_iterator end = parcel->mAccessList.end(); @@ -2712,9 +2688,9 @@ void LLPanelLandAccess::refresh() else { mCheckGroup->set(FALSE); - mCheckGroup->setLabel("Group:"); + mCheckGroup->setLabelArg( "[GROUP]", LLString::null ); mCheckAccess->set(FALSE); - mCheckAccess->setLabel("Avatars:"); + mCheckAccess->setLabelArg( "[LISTED]", llformat("%d",0)); mBtnAddAccess->setEnabled(FALSE); mBtnRemoveAccess->setEnabled(FALSE); mSpinPrice->set((F32)PARCEL_PASS_PRICE_DEFAULT); @@ -2736,9 +2712,7 @@ void LLPanelLandAccess::refreshNames() { gCacheName->getGroupName(parcel->getGroupID(), group_name); } - char label[MAX_STRING]; /*Flawfinder: ignore*/ - snprintf(label, sizeof(label), "Group: %s", group_name); /* Flawfinder: ignore */ - mCheckGroup->setLabel(label); + mCheckGroup->setLabelArg("[GROUP]", LLString(group_name)); } @@ -2904,18 +2878,14 @@ void LLPanelLandBan::refresh() if (parcel) { - char label[256]; /*Flawfinder: ignore*/ - // Display options S32 count = parcel->mBanList.size(); BOOL use_ban = parcel->getParcelFlag(PF_USE_BAN_LIST); mCheck->set( use_ban ); - - snprintf(label, sizeof(label), "Ban these avatars: (%d listed, %d max)", /* Flawfinder: ignore */ - count, PARCEL_MAX_ACCESS_LIST); - mCheck->setLabel( label ); + mCheck->setLabelArg( "[LISTED]", llformat("%d",count)); + mCheck->setLabelArg( "[MAX]", llformat("%d",PARCEL_MAX_ACCESS_LIST)); access_map_const_iterator cit = parcel->mBanList.begin(); access_map_const_iterator end = parcel->mBanList.end(); @@ -2994,7 +2964,7 @@ void LLPanelLandBan::refresh() else { mCheck->set(FALSE); - mCheck->setLabel("Ban these avatars:"); + mCheck->setLabelArg( "[LISTED]", llformat("%d",0)); mCheck->setEnabled(FALSE); mBtnAdd->setEnabled(FALSE); mBtnRemove->setEnabled(FALSE); @@ -3088,82 +3058,6 @@ void LLPanelLandBan::onClickRemove(void* data) } //--------------------------------------------------------------------------- -// LLPanelLandRenters -//--------------------------------------------------------------------------- -LLPanelLandRenters::LLPanelLandRenters(LLParcelSelectionHandle& parcel) -: LLPanel("landrenters", LLRect(0,500,500,0)), mParcel(parcel) -{ - const S32 BTN_WIDTH = 64; - - S32 x = LEFT; - S32 y = mRect.getHeight() - VPAD; - - LLCheckBoxCtrl* check = NULL; - LLButton* btn = NULL; - LLNameListCtrl* list = NULL; - - check = new LLCheckBoxCtrl("RentersCheck", - LLRect(RULER0, y, RIGHT, y-LINE), - "Rent space to these avatars:"); - addChild(check); - mCheckRenters = check; - - y -= VPAD + LINE; - - const S32 ITEMS = 5; - const BOOL NO_MULTIPLE_SELECT = FALSE; - - list = new LLNameListCtrl("RentersList", - LLRect(RULER05, y, RIGHT, y-LINE*ITEMS), - NULL, NULL, - NO_MULTIPLE_SELECT); - list->addSimpleItem("foo tester"); - list->addSimpleItem("bar tester"); - list->setFollows(FOLLOWS_TOP | FOLLOWS_LEFT); - addChild(list); - mListRenters = list; - - y -= VPAD + LINE*ITEMS; - - x = RULER05; - btn = new LLButton("Add...", - LLRect(x, y, x+BTN_WIDTH, y-LINE), - "", - onClickAdd, this); - btn->setFont( LLFontGL::sSansSerifSmall ); - btn->setFollows(FOLLOWS_TOP | FOLLOWS_LEFT); - addChild(btn); - mBtnAddRenter = btn; - - x += HPAD + BTN_WIDTH; - - btn = new LLButton("Remove", - LLRect(x, y, x+BTN_WIDTH, y-LINE), - "", - onClickRemove, this); - btn->setFont( LLFontGL::sSansSerifSmall ); - btn->setFollows(FOLLOWS_TOP | FOLLOWS_LEFT); - addChild(btn); - mBtnRemoveRenter = btn; -} - -LLPanelLandRenters::~LLPanelLandRenters() -{ } - -void LLPanelLandRenters::refresh() -{ } - -// static -void LLPanelLandRenters::onClickAdd(void*) -{ -} - -// static -void LLPanelLandRenters::onClickRemove(void*) -{ -} - -//--------------------------------------------------------------------------- // LLPanelLandCovenant //--------------------------------------------------------------------------- LLPanelLandCovenant::LLPanelLandCovenant(LLParcelSelectionHandle& parcel) diff --git a/linden/indra/newview/llfloaterland.h b/linden/indra/newview/llfloaterland.h index 6e54d12..9eb9172 100644 --- a/linden/indra/newview/llfloaterland.h +++ b/linden/indra/newview/llfloaterland.h @@ -3,6 +3,8 @@ * @author James Cook * @brief "About Land" floater, allowing display and editing of land parcel properties. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERLAND_H @@ -110,7 +113,6 @@ protected: LLPanelLandAccess* mPanelAccess; LLPanelLandBan* mPanelBan; LLPanelLandCovenant* mPanelCovenant; - LLPanelLandRenters* mPanelRenters; LLHandle mParcel; @@ -174,7 +176,7 @@ protected: LLTextBox* mLabelName; LLLineEditor* mEditName; LLTextBox* mLabelDesc; - LLLineEditor* mEditDesc; + LLTextEditor* mEditDesc; LLTextBox* mTextSalePending; @@ -321,6 +323,7 @@ public: static void onClickPublishHelp(void*); virtual BOOL postBuild(); + virtual void draw(); protected: LLCheckBoxCtrl* mCheckEditObjects; diff --git a/linden/indra/newview/llfloaterlandholdings.cpp b/linden/indra/newview/llfloaterlandholdings.cpp index 9ebd18c..5aac949 100644 --- a/linden/indra/newview/llfloaterlandholdings.cpp +++ b/linden/indra/newview/llfloaterlandholdings.cpp @@ -2,6 +2,8 @@ * @file llfloaterlandholdings.cpp * @brief "My Land" floater showing all your land parcels. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llfloaterlandholdings.h b/linden/indra/newview/llfloaterlandholdings.h index 30c4aea..3490547 100644 --- a/linden/indra/newview/llfloaterlandholdings.h +++ b/linden/indra/newview/llfloaterlandholdings.h @@ -2,6 +2,8 @@ * @file llfloaterlandholdings.h * @brief "My Land" floater showing all your land parcels. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERLANDHOLDINGS_H diff --git a/linden/indra/newview/llfloatermap.cpp b/linden/indra/newview/llfloatermap.cpp index 97d0041..952c56a 100644 --- a/linden/indra/newview/llfloatermap.cpp +++ b/linden/indra/newview/llfloatermap.cpp @@ -2,6 +2,8 @@ * @file llfloatermap.cpp * @brief The "mini-map" or radar in the upper right part of the screen. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -217,47 +220,3 @@ void LLFloaterMap::toggle(void*) } } } - - -BOOL process_secondlife_url(LLString url) -{ - S32 strpos, strpos2; - - LLString slurlID = "slurl.com/secondlife/"; - strpos = url.find(slurlID); - - if (strpos < 0) - { - slurlID="secondlife://"; - strpos = url.find(slurlID); - } - - if (strpos >= 0) - { - LLString simname; - - strpos+=slurlID.length(); - strpos2=url.find("/",strpos); - if (strpos2 < strpos) strpos2=url.length(); - simname="secondlife://" + url.substr(strpos,url.length() - strpos); - - LLURLSimString::setString( simname ); - LLURLSimString::parse(); - - // if there is a world map - if ( gFloaterWorldMap ) - { - // mark where the destination is - gFloaterWorldMap->trackURL( LLURLSimString::sInstance.mSimName.c_str(), - LLURLSimString::sInstance.mX, - LLURLSimString::sInstance.mY, - LLURLSimString::sInstance.mZ ); - - // display map - LLFloaterWorldMap::show( NULL, TRUE ); - }; - - return TRUE; - } - return FALSE; -} diff --git a/linden/indra/newview/llfloatermap.h b/linden/indra/newview/llfloatermap.h index 0f96cc7..24f7b9f 100644 --- a/linden/indra/newview/llfloatermap.h +++ b/linden/indra/newview/llfloatermap.h @@ -2,6 +2,8 @@ * @file llfloatermap.h * @brief The "mini-map" or radar in the upper right part of the screen. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERMAP_H @@ -66,6 +69,4 @@ protected: extern LLFloaterMap *gFloaterMap; -BOOL process_secondlife_url(LLString url); - #endif // LL_LLFLOATERMAP_H diff --git a/linden/indra/newview/llfloatermute.cpp b/linden/indra/newview/llfloatermute.cpp index 0f11042..a22115b 100644 --- a/linden/indra/newview/llfloatermute.cpp +++ b/linden/indra/newview/llfloatermute.cpp @@ -2,6 +2,8 @@ * @file llfloatermute.cpp * @brief Container for mute list * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llfloatermute.h b/linden/indra/newview/llfloatermute.h index 4f26412..76cc6e4 100644 --- a/linden/indra/newview/llfloatermute.h +++ b/linden/indra/newview/llfloatermute.h @@ -2,6 +2,8 @@ * @file llfloatermute.h * @brief Container for mute list * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERMUTE_H diff --git a/linden/indra/newview/llfloaternamedesc.cpp b/linden/indra/newview/llfloaternamedesc.cpp index 3f90752..392696d 100644 --- a/linden/indra/newview/llfloaternamedesc.cpp +++ b/linden/indra/newview/llfloaternamedesc.cpp @@ -2,6 +2,8 @@ * @file llfloaternamedesc.cpp * @brief LLFloaterNameDesc class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llfloaternamedesc.h b/linden/indra/newview/llfloaternamedesc.h index 9f2d545..2b0ec9b 100644 --- a/linden/indra/newview/llfloaternamedesc.h +++ b/linden/indra/newview/llfloaternamedesc.h @@ -2,6 +2,8 @@ * @file llfloaternamedesc.h * @brief LLFloaterNameDesc class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERNAMEDESC_H diff --git a/linden/indra/newview/llfloaternewim.cpp b/linden/indra/newview/llfloaternewim.cpp index 844259f..b21ad31 100644 --- a/linden/indra/newview/llfloaternewim.cpp +++ b/linden/indra/newview/llfloaternewim.cpp @@ -2,6 +2,8 @@ * @file llfloaternewim.cpp * @brief Panel allowing the user to create a new IM session. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llfloaternewim.h b/linden/indra/newview/llfloaternewim.h index 06765b1..c7ea654 100644 --- a/linden/indra/newview/llfloaternewim.h +++ b/linden/indra/newview/llfloaternewim.h @@ -2,6 +2,8 @@ * @file llfloaternewim.h * @brief Panel allowing the user to create a new IM session. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_FLOATER_NEW_IM_H diff --git a/linden/indra/newview/llfloateropenobject.cpp b/linden/indra/newview/llfloateropenobject.cpp index b907c39..0b79c85 100644 --- a/linden/indra/newview/llfloateropenobject.cpp +++ b/linden/indra/newview/llfloateropenobject.cpp @@ -2,6 +2,8 @@ * @file llfloateropenobject.cpp * @brief LLFloaterOpenObject class implementation * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /* @@ -64,7 +67,7 @@ LLFloaterOpenObject::LLFloaterOpenObject() childSetAction("copy_to_inventory_button", onClickMoveToInventory, this); childSetAction("copy_and_wear_button", onClickMoveAndWear, this); - childSetTextArg("object_name", "[DESC]", "Object"); + childSetTextArg("object_name", "[DESC]", LLString("Object") ); // *Note: probably do not want to translate this } LLFloaterOpenObject::~LLFloaterOpenObject() diff --git a/linden/indra/newview/llfloateropenobject.h b/linden/indra/newview/llfloateropenobject.h index 46954da..cd656bc 100644 --- a/linden/indra/newview/llfloateropenobject.h +++ b/linden/indra/newview/llfloateropenobject.h @@ -2,6 +2,8 @@ * @file llfloateropenobject.h * @brief LLFloaterOpenObject class definition * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /* diff --git a/linden/indra/newview/llfloaterpermissionsmgr.cpp b/linden/indra/newview/llfloaterpermissionsmgr.cpp index f98c200..cb77551 100644 --- a/linden/indra/newview/llfloaterpermissionsmgr.cpp +++ b/linden/indra/newview/llfloaterpermissionsmgr.cpp @@ -2,6 +2,8 @@ * @file llfloaterpermissionsmgr.cpp * @brief for user control of script permissions * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llfloaterpermissionsmgr.h b/linden/indra/newview/llfloaterpermissionsmgr.h index 1c87e04..16eeaa9 100644 --- a/linden/indra/newview/llfloaterpermissionsmgr.h +++ b/linden/indra/newview/llfloaterpermissionsmgr.h @@ -2,6 +2,8 @@ * @file llfloaterpermissionsmgr.h * @brief for user control of script permissions * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERPERMISSIONSMGR_H diff --git a/linden/indra/newview/llfloaterpostcard.cpp b/linden/indra/newview/llfloaterpostcard.cpp index 94ff5ed..8dcdb99 100644 --- a/linden/indra/newview/llfloaterpostcard.cpp +++ b/linden/indra/newview/llfloaterpostcard.cpp @@ -2,6 +2,8 @@ * @file llfloaterpostcard.cpp * @brief Postcard send floater, allows setting name, e-mail address, etc. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -354,7 +357,7 @@ void LLFloaterPostcard::onMsgFormFocusRecieved(LLUICtrl* receiver, void* data) if(msgForm && msgForm == receiver && msgForm->hasFocus() && !(self->mHasFirstMsgFocus)) { self->mHasFirstMsgFocus = true; - msgForm->setText(LLString("")); + msgForm->setText(LLString::null); } } } @@ -377,7 +380,6 @@ void LLFloaterPostcard::missingSubjMsgAlertCallback(S32 option, void* data) { // The user never switched focus to the messagee window. // Using the default string. - // XUI: translate self->childSetValue("msg_form", self->childGetText("default_message")); } diff --git a/linden/indra/newview/llfloaterpostcard.h b/linden/indra/newview/llfloaterpostcard.h index 2c5327e..78da8b5 100644 --- a/linden/indra/newview/llfloaterpostcard.h +++ b/linden/indra/newview/llfloaterpostcard.h @@ -2,6 +2,8 @@ * @file llfloaterpostcard.h * @brief Postcard send floater, allows setting name, e-mail address, etc. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERPOSTCARD_H diff --git a/linden/indra/newview/llfloaterpreference.cpp b/linden/indra/newview/llfloaterpreference.cpp index 0b3e856..f061018 100644 --- a/linden/indra/newview/llfloaterpreference.cpp +++ b/linden/indra/newview/llfloaterpreference.cpp @@ -2,6 +2,8 @@ * @file llfloaterpreference.cpp * @brief LLPreferenceCore class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /* diff --git a/linden/indra/newview/llfloaterpreference.h b/linden/indra/newview/llfloaterpreference.h index df22c1e..db77ebd 100644 --- a/linden/indra/newview/llfloaterpreference.h +++ b/linden/indra/newview/llfloaterpreference.h @@ -2,6 +2,8 @@ * @file llfloaterpreference.h * @brief LLPreferenceCore class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /* diff --git a/linden/indra/newview/llfloaterproperties.cpp b/linden/indra/newview/llfloaterproperties.cpp index 546270e..538e841 100644 --- a/linden/indra/newview/llfloaterproperties.cpp +++ b/linden/indra/newview/llfloaterproperties.cpp @@ -2,6 +2,8 @@ * @file llfloaterproperties.cpp * @brief A floater which shows an inventory item's properties. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -56,14 +59,6 @@ #include "llvieweruictrlfactory.h" -///---------------------------------------------------------------------------- -/// Local function declarations, constants, enums, and typedefs -///---------------------------------------------------------------------------- - -const char* YOU_CAN = "You can:"; -const char* OWNER_CAN = "Owner can: "; - - //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ // Class LLPropertiesObserver // @@ -299,22 +294,11 @@ void LLFloaterProperties::refreshFromItem(LLInventoryItem* item) childSetEnabled("LabelItemNameTitle",TRUE); childSetEnabled("LabelItemName",is_modifiable); - const char EMPTY_STRING[1] = ""; /* Flawfinder: ignore */ - const char* txt = EMPTY_STRING; - if(!item->getName().empty()) - { - txt = item->getName().c_str(); - } - childSetText("LabelItemName",txt); + childSetText("LabelItemName",item->getName()); childSetEnabled("LabelItemDescTitle",TRUE); childSetEnabled("LabelItemDesc",is_modifiable); childSetVisible("IconLocked",!is_modifiable); - txt = EMPTY_STRING; - if(!item->getDescription().empty()) - { - txt = item->getDescription().c_str(); - } - childSetText("LabelItemDesc",txt); + childSetText("LabelItemDesc",item->getDescription()); ////////////////// // CREATOR NAME // @@ -341,7 +325,7 @@ void LLFloaterProperties::refreshFromItem(LLInventoryItem* item) childSetEnabled("BtnCreator",FALSE); childSetEnabled("LabelCreatorTitle",FALSE); childSetEnabled("LabelCreatorName",FALSE); - childSetText("LabelCreatorName","(unknown)"); // XUI:translate + childSetText("LabelCreatorName",childGetText("unknown")); } //////////////// @@ -373,20 +357,22 @@ void LLFloaterProperties::refreshFromItem(LLInventoryItem* item) childSetEnabled("BtnOwner",FALSE); childSetEnabled("LabelOwnerTitle",FALSE); childSetEnabled("LabelOwnerName",FALSE); - childSetText("LabelOwnerName","(public)"); // XUI:translate + childSetText("LabelOwnerName",childGetText("public")); } ////////////////// // ACQUIRE DATE // ////////////////// + + // *TODO: Localize / translate this time_t time_utc = (time_t)item->getCreationDate(); if (0 == time_utc) { - childSetText("LabelAcquiredDate","(unknown)"); + childSetText("LabelAcquiredDate",childGetText("unknown")); } else { - childSetText("LabelAcquiredDate", ctime(&time_utc) ); + childSetText("LabelAcquiredDate", LLString(ctime(&time_utc)) ); } /////////////////////// @@ -394,11 +380,11 @@ void LLFloaterProperties::refreshFromItem(LLInventoryItem* item) /////////////////////// if(can_agent_manipulate) { - childSetText("OwnerLabel",YOU_CAN); + childSetText("OwnerLabel",childGetText("you_can")); } else { - childSetText("OwnerLabel",OWNER_CAN); + childSetText("OwnerLabel",childGetText("owner_can")); } U32 base_mask = perm.getMaskBase(); @@ -433,30 +419,33 @@ void LLFloaterProperties::refreshFromItem(LLInventoryItem* item) overwrite_group = flags & LLInventoryItem::II_FLAGS_OBJECT_PERM_OVERWRITE_GROUP; } - char perm_string[11]; /* Flawfinder: ignore */ + std::string perm_string; - snprintf(perm_string, sizeof(perm_string), "B: "); /* Flawfinder: ignore */ - mask_to_string(base_mask, perm_string+3); + perm_string = "B: "; + perm_string += mask_to_string(base_mask); childSetText("BaseMaskDebug",perm_string); childSetVisible("BaseMaskDebug",TRUE); - snprintf(perm_string, sizeof(perm_string), "O: "); /* Flawfinder: ignore */ - mask_to_string(owner_mask, perm_string+3); + perm_string = "O: "; + perm_string += mask_to_string(owner_mask); childSetText("OwnerMaskDebug",perm_string); childSetVisible("OwnerMaskDebug",TRUE); - snprintf(perm_string, sizeof(perm_string), "G%s: ", overwrite_group ? "*" : ""); /* Flawfinder: ignore */ - mask_to_string(group_mask, perm_string + (overwrite_group ? 4 : 3)); + perm_string = "G"; + perm_string += overwrite_group ? "*: " : ": "; + perm_string += perm_string += mask_to_string(group_mask); childSetText("GroupMaskDebug",perm_string); childSetVisible("GroupMaskDebug",TRUE); - snprintf(perm_string, sizeof(perm_string), "E%s: ", overwrite_everyone ? "*" : ""); /* Flawfinder: ignore */ - mask_to_string(everyone_mask, perm_string + (overwrite_everyone ? 4 : 3)); + perm_string = "E"; + perm_string += overwrite_everyone ? "*: " : ": "; + perm_string += mask_to_string(everyone_mask); childSetText("EveryoneMaskDebug",perm_string); childSetVisible("EveryoneMaskDebug",TRUE); - snprintf(perm_string, sizeof(perm_string), "N%s: ", slam_perm ? "*" : ""); /* Flawfinder: ignore */ - mask_to_string(next_owner_mask, perm_string + (slam_perm ? 4 : 3)); + perm_string = "N"; + perm_string += slam_perm ? "*: " : ": "; + perm_string += mask_to_string(next_owner_mask); childSetText("NextMaskDebug",perm_string); childSetVisible("NextMaskDebug",TRUE); } @@ -568,14 +557,14 @@ void LLFloaterProperties::refreshFromItem(LLInventoryItem* item) if (is_for_sale) { radioSaleType->setSelectedIndex((S32)sale_info.getSaleType() - 1); - char numerical_price[MAX_STRING]; /* Flawfinder: ignore */ - snprintf(numerical_price, MAX_STRING, "%d", sale_info.getSalePrice()); /* Flawfinder: ignore */ - childSetText("EditPrice",numerical_price); + S32 numerical_price; + numerical_price = sale_info.getSalePrice(); + childSetText("EditPrice",llformat("%d",numerical_price)); } else { radioSaleType->setSelectedIndex(-1); - childSetText("EditPrice",""); + childSetText("EditPrice",llformat("%d",0)); } } diff --git a/linden/indra/newview/llfloaterproperties.h b/linden/indra/newview/llfloaterproperties.h index deaf1d4..7b1cb5d 100644 --- a/linden/indra/newview/llfloaterproperties.h +++ b/linden/indra/newview/llfloaterproperties.h @@ -2,6 +2,8 @@ * @file llfloaterproperties.h * @brief A floater which shows an inventory item's properties. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERPROPERTIES_H diff --git a/linden/indra/newview/llfloaterregioninfo.cpp b/linden/indra/newview/llfloaterregioninfo.cpp index f7c05b5..5833c2f 100644 --- a/linden/indra/newview/llfloaterregioninfo.cpp +++ b/linden/indra/newview/llfloaterregioninfo.cpp @@ -3,6 +3,8 @@ * @author Aaron Brashears * @brief Implementation of the region info and controls floater and panels. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -201,6 +204,7 @@ LLFloaterRegionInfo::LLFloaterRegionInfo(const LLRect& rect) : mInfoPanels.push_back((LLPanelRegionInfo*)panel); gUICtrlFactory->buildPanel(panel, "panel_region_covenant.xml"); mTab->addTabPanel(panel, panel->getLabel(), FALSE); + } LLFloaterRegionInfo::~LLFloaterRegionInfo() @@ -234,6 +238,7 @@ void LLFloaterRegionInfo::show(LLViewerRegion* region) msg->addUUID("AgentID", gAgent.getID()); msg->addUUID("SessionID", gAgent.getSessionID()); gAgent.sendReliableMessage(); + } // static @@ -325,6 +330,7 @@ void LLFloaterRegionInfo::processRegionInfo(LLMessageSystem* msg) panel->childSetValue("restrict_pushobject", (region_flags & REGION_FLAGS_RESTRICT_PUSHOBJECT) ? TRUE : FALSE ); panel->childSetValue("allow_land_resell_check", (region_flags & REGION_FLAGS_BLOCK_LAND_RESELL) ? FALSE : TRUE ); panel->childSetValue("allow_parcel_changes_check", (region_flags & REGION_FLAGS_ALLOW_PARCEL_CHANGES) ? TRUE : FALSE ); + panel->childSetValue("block_parcel_search_check", (region_flags & REGION_FLAGS_BLOCK_PARCEL_SEARCH) ? TRUE : FALSE ); panel->childSetValue("agent_limit_spin", LLSD((F32)agent_limit) ); panel->childSetValue("object_bonus_spin", LLSD(object_bonus_factor) ); panel->childSetValue("access_combo", LLSD(LLViewerRegion::accessToString(sim_access)) ); @@ -557,6 +563,7 @@ BOOL LLPanelRegionGeneralInfo::postBuild() initCtrl("object_bonus_spin"); initCtrl("access_combo"); initCtrl("restrict_pushobject"); + initCtrl("block_parcel_search_check"); initHelpBtn("terraform_help", "HelpRegionBlockTerraform"); initHelpBtn("fly_help", "HelpRegionBlockFly"); @@ -567,6 +574,7 @@ BOOL LLPanelRegionGeneralInfo::postBuild() initHelpBtn("restrict_pushobject_help", "HelpRegionRestrictPushObject"); initHelpBtn("land_resell_help", "HelpRegionLandResell"); initHelpBtn("parcel_changes_help", "HelpParcelChanges"); + initHelpBtn("parcel_search_help", "HelpRegionSearch"); childSetAction("kick_btn", onClickKick, this); childSetAction("kick_all_btn", onClickKickAll, this); @@ -692,52 +700,78 @@ void LLPanelRegionGeneralInfo::onClickManageTelehub(void* data) // strings[6] = sim access (0 = unknown, 13 = PG, 21 = Mature) // strings[7] = restrict pushobject // strings[8] = 'Y' - allow parcel subdivide, 'N' - not +// strings[9] = 'Y' - block parcel search, 'N' - allow BOOL LLPanelRegionGeneralInfo::sendUpdate() { llinfos << "LLPanelRegionGeneralInfo::sendUpdate()" << llendl; - strings_t strings; - //integers_t integers; - char buffer[MAX_STRING]; /* Flawfinder: ignore*/ - snprintf(buffer, MAX_STRING, "%s", (childGetValue("block_terraform_check").asBoolean() ? "Y" : "N")); /* Flawfinder: ignore */ - strings.push_back(strings_t::value_type(buffer)); - - snprintf(buffer, MAX_STRING, "%s", (childGetValue("block_fly_check").asBoolean() ? "Y" : "N")); /* Flawfinder: ignore */ - strings.push_back(strings_t::value_type(buffer)); - snprintf(buffer, MAX_STRING, "%s", (childGetValue("allow_damage_check").asBoolean() ? "Y" : "N")); /* Flawfinder: ignore */ - strings.push_back(strings_t::value_type(buffer)); + // First try using a Cap. If that fails use the old method. + LLSD body; + std::string url = gAgent.getRegion()->getCapability("DispatchRegionInfo"); + if (!url.empty()) + { + body["block_terraform"] = childGetValue("block_terraform_check"); + body["block_fly"] = childGetValue("block_fly_check"); + body["allow_damage"] = childGetValue("allow_damage_check"); + body["allow_land_resell"] = childGetValue("allow_land_resell_check"); + body["agent_limit"] = childGetValue("agent_limit_spin"); + body["prim_bonus"] = childGetValue("object_bonus_spin"); + body["sim_access"] = childGetValue("access_combo"); + body["restrict_pushobject"] = childGetValue("restrict_pushobject"); + body["allow_parcel_changes"] = childGetValue("allow_parcel_changes_check"); + body["block_parcel_search"] = childGetValue("block_parcel_search_check"); + LLHTTPClient::post(url, body, new LLHTTPClient::Responder()); + } + else + { + strings_t strings; + char buffer[MAX_STRING]; /* Flawfinder: ignore*/ + + snprintf(buffer, MAX_STRING, "%s", (childGetValue("block_terraform_check").asBoolean() ? "Y" : "N")); /* Flawfinder: ignore */ + strings.push_back(strings_t::value_type(buffer)); + + snprintf(buffer, MAX_STRING, "%s", (childGetValue("block_fly_check").asBoolean() ? "Y" : "N")); /* Flawfinder: ignore */ + strings.push_back(strings_t::value_type(buffer)); + + snprintf(buffer, MAX_STRING, "%s", (childGetValue("allow_damage_check").asBoolean() ? "Y" : "N")); /* Flawfinder: ignore */ + strings.push_back(strings_t::value_type(buffer)); - snprintf(buffer, MAX_STRING, "%s", (childGetValue("allow_land_resell_check").asBoolean() ? "Y" : "N")); /* Flawfinder: ignore */ - strings.push_back(strings_t::value_type(buffer)); + snprintf(buffer, MAX_STRING, "%s", (childGetValue("allow_land_resell_check").asBoolean() ? "Y" : "N")); /* Flawfinder: ignore */ + strings.push_back(strings_t::value_type(buffer)); - F32 value = (F32)childGetValue("agent_limit_spin").asReal(); - snprintf(buffer, MAX_STRING, "%f", value); /* Flawfinder: ignore */ - strings.push_back(strings_t::value_type(buffer)); + F32 value = (F32)childGetValue("agent_limit_spin").asReal(); + snprintf(buffer, MAX_STRING, "%f", value); /* Flawfinder: ignore */ + strings.push_back(strings_t::value_type(buffer)); - value = (F32)childGetValue("object_bonus_spin").asReal(); - snprintf(buffer, MAX_STRING, "%f", value); /* Flawfinder: ignore */ - strings.push_back(strings_t::value_type(buffer)); + value = (F32)childGetValue("object_bonus_spin").asReal(); + snprintf(buffer, MAX_STRING, "%f", value); /* Flawfinder: ignore */ + strings.push_back(strings_t::value_type(buffer)); - U8 access = LLViewerRegion::stringToAccess(childGetValue("access_combo").asString().c_str()); - snprintf(buffer, MAX_STRING, "%d", (S32)access); /* Flawfinder: ignore */ - strings.push_back(strings_t::value_type(buffer)); + U8 access = LLViewerRegion::stringToAccess(childGetValue("access_combo").asString().c_str()); + snprintf(buffer, MAX_STRING, "%d", (S32)access); /* Flawfinder: ignore */ + strings.push_back(strings_t::value_type(buffer)); - snprintf(buffer, MAX_STRING, "%s", (childGetValue("restrict_pushobject").asBoolean() ? "Y" : "N")); /* Flawfinder: ignore */ - strings.push_back(strings_t::value_type(buffer)); + snprintf(buffer, MAX_STRING, "%s", (childGetValue("restrict_pushobject").asBoolean() ? "Y" : "N")); /* Flawfinder: ignore */ + strings.push_back(strings_t::value_type(buffer)); - snprintf(buffer, MAX_STRING, "%s", (childGetValue("allow_parcel_changes_check").asBoolean() ? "Y" : "N")); /* Flawfinder: ignore */ - strings.push_back(strings_t::value_type(buffer)); + snprintf(buffer, MAX_STRING, "%s", (childGetValue("allow_parcel_changes_check").asBoolean() ? "Y" : "N")); /* Flawfinder: ignore */ + strings.push_back(strings_t::value_type(buffer)); - LLUUID invoice(LLFloaterRegionInfo::getLastInvoice()); - sendEstateOwnerMessage(gMessageSystem, "setregioninfo", invoice, strings); + LLUUID invoice(LLFloaterRegionInfo::getLastInvoice()); + sendEstateOwnerMessage(gMessageSystem, "setregioninfo", invoice, strings); - LLViewerRegion* region = gAgent.getRegion(); - if (region - && access != region->getSimAccess() ) /* Flawfinder: ignore */ - { - gViewerWindow->alertXml("RegionMaturityChange"); + LLViewerRegion* region = gAgent.getRegion(); + if (region + && access != region->getSimAccess() ) /* Flawfinder: ignore */ + { + gViewerWindow->alertXml("RegionMaturityChange"); + } } + + //integers_t integers; + + return TRUE; } diff --git a/linden/indra/newview/llfloaterregioninfo.h b/linden/indra/newview/llfloaterregioninfo.h index 6c53a7d..656583b 100644 --- a/linden/indra/newview/llfloaterregioninfo.h +++ b/linden/indra/newview/llfloaterregioninfo.h @@ -3,6 +3,8 @@ * @author Aaron Brashears * @brief Declaration of the region info and controls floater and panels. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERREGIONINFO_H diff --git a/linden/indra/newview/llfloaterreleasemsg.cpp b/linden/indra/newview/llfloaterreleasemsg.cpp index 50df25a..87ff436 100644 --- a/linden/indra/newview/llfloaterreleasemsg.cpp +++ b/linden/indra/newview/llfloaterreleasemsg.cpp @@ -2,6 +2,8 @@ * @file llfloaterreleasemsg.cpp * @brief In-world HTML dialog * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llfloaterreleasemsg.h b/linden/indra/newview/llfloaterreleasemsg.h index 026b9da..2644c76 100644 --- a/linden/indra/newview/llfloaterreleasemsg.h +++ b/linden/indra/newview/llfloaterreleasemsg.h @@ -1,6 +1,8 @@ /** * @file LLFloaterReleaseMsg.h * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERRELMSG_H diff --git a/linden/indra/newview/llfloaterreporter.cpp b/linden/indra/newview/llfloaterreporter.cpp index f37f8a0..a7cd211 100644 --- a/linden/indra/newview/llfloaterreporter.cpp +++ b/linden/indra/newview/llfloaterreporter.cpp @@ -2,6 +2,8 @@ * @file llfloaterreporter.cpp * @brief Bug and abuse reports. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -174,8 +177,8 @@ LLFloaterReporter::LLFloaterReporter( setVisible(TRUE); // Default text to be blank - childSetText("object_name", ""); - childSetText("owner_name", ""); + childSetText("object_name", LLString::null); + childSetText("owner_name", LLString::null); childSetFocus("summary_edit"); @@ -458,8 +461,8 @@ void LLFloaterReporter::onClickObjPicker(void *userdata) gToolObjPicker->setExitCallback(LLFloaterReporter::closePickTool, self); gToolMgr->setTransientTool(gToolObjPicker); self->mPicking = TRUE; - self->childSetText("object_name", ""); - self->childSetText("owner_name", ""); + self->childSetText("object_name", LLString::null); + self->childSetText("owner_name", LLString::null); LLButton* pick_btn = LLUICtrlFactory::getButtonByName(self, "pick_btn"); if (pick_btn) pick_btn->setToggleState(TRUE); } @@ -578,7 +581,7 @@ LLFloaterReporter* LLFloaterReporter::createNewBugReporter() -void LLFloaterReporter::setPickedObjectProperties(const char *object_name, const char *owner_name, const LLUUID owner_id) +void LLFloaterReporter::setPickedObjectProperties(const LLString& object_name, const LLString& owner_name, const LLUUID owner_id) { childSetText("object_name", object_name); childSetText("owner_name", owner_name); diff --git a/linden/indra/newview/llfloaterreporter.h b/linden/indra/newview/llfloaterreporter.h index 32fff6b..771a6a3 100644 --- a/linden/indra/newview/llfloaterreporter.h +++ b/linden/indra/newview/llfloaterreporter.h @@ -3,6 +3,8 @@ * @author Andrew Meadows * @brief Bug and abuse reports. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERREPORTER_H @@ -106,7 +109,7 @@ public: // static static void processRegionInfo(LLMessageSystem* msg); - void setPickedObjectProperties(const char *object_name, const char *owner_name, const LLUUID owner_id); + void setPickedObjectProperties(const LLString& object_name, const LLString& owner_name, const LLUUID owner_id); private: void takeScreenshot(); diff --git a/linden/indra/newview/llfloatersaveavatar.cpp b/linden/indra/newview/llfloatersaveavatar.cpp index edc740d..d5bcda5 100644 --- a/linden/indra/newview/llfloatersaveavatar.cpp +++ b/linden/indra/newview/llfloatersaveavatar.cpp @@ -2,6 +2,8 @@ * @file llfloatersaveavatar.cpp * @brief write out avatar as CAL3D file * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llfloatersaveavatar.h b/linden/indra/newview/llfloatersaveavatar.h index 50cdb12..e505b59 100644 --- a/linden/indra/newview/llfloatersaveavatar.h +++ b/linden/indra/newview/llfloatersaveavatar.h @@ -2,6 +2,8 @@ * @file llfloatersaveavatar.h * @brief write out avatar as CAL3D file * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERSAVEAVATAR_H diff --git a/linden/indra/newview/llfloaterscriptdebug.cpp b/linden/indra/newview/llfloaterscriptdebug.cpp index 82f5ce8..9d600be 100644 --- a/linden/indra/newview/llfloaterscriptdebug.cpp +++ b/linden/indra/newview/llfloaterscriptdebug.cpp @@ -2,6 +2,8 @@ * @file llfloaterscriptdebug.cpp * @brief Chat window for showing script errors and warnings * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llfloaterscriptdebug.h b/linden/indra/newview/llfloaterscriptdebug.h index 891ec3b..0fefb3a 100644 --- a/linden/indra/newview/llfloaterscriptdebug.h +++ b/linden/indra/newview/llfloaterscriptdebug.h @@ -2,6 +2,8 @@ * @file llfloaterscriptdebug.h * @brief Shows error and warning output from scripts * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERSCRIPTDEBUG_H diff --git a/linden/indra/newview/llfloatersellland.cpp b/linden/indra/newview/llfloatersellland.cpp index 49cb14e..9bf1f78 100644 --- a/linden/indra/newview/llfloatersellland.cpp +++ b/linden/indra/newview/llfloatersellland.cpp @@ -1,6 +1,8 @@ /** * @file llfloatersellland.cpp * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llfloatersellland.h b/linden/indra/newview/llfloatersellland.h index 1f0af61..8cada4e 100644 --- a/linden/indra/newview/llfloatersellland.h +++ b/linden/indra/newview/llfloatersellland.h @@ -1,6 +1,8 @@ /** * @file llfloatersellland.h * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERSELLLAND_H diff --git a/linden/indra/newview/llfloatersnapshot.cpp b/linden/indra/newview/llfloatersnapshot.cpp index 7cb92ff..3bc172c 100644 --- a/linden/indra/newview/llfloatersnapshot.cpp +++ b/linden/indra/newview/llfloatersnapshot.cpp @@ -2,6 +2,8 @@ * @file llfloatersnapshot.cpp * @brief Snapshot preview window, allowing saving, e-mailing, etc. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -1138,7 +1141,8 @@ void LLFloaterSnapshot::Impl::onCommitResolution(LLUICtrl* ctrl, void* data) } else if (width == -1 || height == -1) { - // leave width and height when entering custom value + // load last custom value + previewp->setSize(gSavedSettings.getS32("LastSnapshotWidth"), gSavedSettings.getS32("LastSnapshotHeight")); } else { @@ -1199,15 +1203,18 @@ void LLFloaterSnapshot::Impl::onCommitCustomResolution(LLUICtrl *ctrl, void* dat LLFloaterSnapshot *view = (LLFloaterSnapshot *)data; if (view) { + S32 w = llfloor((F32)view->childGetValue("snapshot_width").asReal()); + S32 h = llfloor((F32)view->childGetValue("snapshot_height").asReal()); + + gSavedSettings.setS32("LastSnapshotWidth", w); + gSavedSettings.setS32("LastSnapshotHeight", h); + LLSnapshotLivePreview* previewp = getPreviewView(view); if (previewp) { S32 curw,curh; previewp->getSize(curw, curh); - S32 w = llfloor((F32)view->childGetValue("snapshot_width").asReal()); - S32 h = llfloor((F32)view->childGetValue("snapshot_height").asReal()); - if (w != curw || h != curh) { previewp->setSize(w,h); @@ -1291,8 +1298,8 @@ BOOL LLFloaterSnapshot::postBuild() childSetValue("layer_types", "colors"); childSetEnabled("layer_types", FALSE); - childSetValue("snapshot_width", gViewerWindow->getWindowDisplayWidth()); - childSetValue("snapshot_height", gViewerWindow->getWindowDisplayHeight()); + childSetValue("snapshot_width", gSavedSettings.getS32("LastSnapshotWidth")); + childSetValue("snapshot_height", gSavedSettings.getS32("LastSnapshotHeight")); childSetValue("freeze_frame_check", gSavedSettings.getBOOL("UseFreezeFrame")); childSetCommitCallback("freeze_frame_check", Impl::onCommitFreezeFrame, this); @@ -1345,16 +1352,15 @@ void LLFloaterSnapshot::draw() childSetEnabled("send_btn", previewp->getSnapshotUpToDate()); } - //XUI:translate if (previewp->getSnapshotUpToDate()) { LLString bytes_string; gResMgr->getIntegerString(bytes_string, previewp->getDataSize()); - childSetTextArg("file_size_label", "[SIZE]", llformat("%s bytes", bytes_string.c_str())); + childSetTextArg("file_size_label", "[SIZE]", bytes_string); } else { - childSetTextArg("file_size_label", "[SIZE]", "unknown"); + childSetTextArg("file_size_label", "[SIZE]", childGetText("unknwon")); childSetColor("file_size_label", gColors.getColor( "LabelTextColor" )); } childSetEnabled("upload_btn", previewp->getSnapshotUpToDate()); @@ -1363,7 +1369,7 @@ void LLFloaterSnapshot::draw() } else { - childSetTextArg("file_size_label", "[SIZE]", "unknown"); + childSetTextArg("file_size_label", "[SIZE]", LLString("???")); childSetEnabled("upload_btn", FALSE); childSetEnabled("send_btn", FALSE); childSetEnabled("save_btn", FALSE); diff --git a/linden/indra/newview/llfloatersnapshot.h b/linden/indra/newview/llfloatersnapshot.h index deefc6d..cf1e6bd 100644 --- a/linden/indra/newview/llfloatersnapshot.h +++ b/linden/indra/newview/llfloatersnapshot.h @@ -2,6 +2,8 @@ * @file llfloatersnapshot.h * @brief Snapshot preview window, allowing saving, e-mailing, etc. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERSNAPSHOT_H diff --git a/linden/indra/newview/llfloatertelehub.cpp b/linden/indra/newview/llfloatertelehub.cpp index e48b6ca..95a47bb 100644 --- a/linden/indra/newview/llfloatertelehub.cpp +++ b/linden/indra/newview/llfloatertelehub.cpp @@ -3,6 +3,8 @@ * @author James Cook * @brief LLFloaterTelehub class implementation * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -126,11 +129,8 @@ void LLFloaterTelehub::draw() // Per-frame updates, because we don't have a selection manager observer. void LLFloaterTelehub::refresh() { - LLViewerObject* object = mObjectSelection->getFirstRootObject(); - if(!object) - { - object = mObjectSelection->getFirstObject(); - } + const BOOL children_ok = TRUE; + LLViewerObject* object = mObjectSelection->getFirstRootObject(children_ok); BOOL have_selection = (object != NULL); BOOL all_volume = gSelectMgr->selectionAllPCode( LL_PCODE_VOLUME ); diff --git a/linden/indra/newview/llfloatertelehub.h b/linden/indra/newview/llfloatertelehub.h index 33e9516..5b9821e 100644 --- a/linden/indra/newview/llfloatertelehub.h +++ b/linden/indra/newview/llfloatertelehub.h @@ -3,6 +3,8 @@ * @author James Cook * @brief LLFloaterTelehub class definition * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERTELEHUB_H diff --git a/linden/indra/newview/llfloatertest.cpp b/linden/indra/newview/llfloatertest.cpp index 6719a38..5af34a8 100644 --- a/linden/indra/newview/llfloatertest.cpp +++ b/linden/indra/newview/llfloatertest.cpp @@ -3,6 +3,8 @@ * @author James Cook * @brief Torture-test floater for all UI elements * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -181,8 +184,7 @@ LLFloaterTestImpl::LLFloaterTestImpl() y -= VPAD + LINE; btn = new LLButton("unicode_btn", LLRect(LEFT, y, LEFT+100, y-20)); - btn->setLabelUnselected("unicode"); - btn->setLabelSelected("unicode"); + btn->setLabel(LLString("unicode")); panel->addChild(btn); y -= VPAD + 20; diff --git a/linden/indra/newview/llfloatertest.h b/linden/indra/newview/llfloatertest.h index afb0683..9979047 100644 --- a/linden/indra/newview/llfloatertest.h +++ b/linden/indra/newview/llfloatertest.h @@ -3,6 +3,8 @@ * @author James Cook * @brief Torture-test floater for all UI elements * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERTEST_H diff --git a/linden/indra/newview/llfloatertools.cpp b/linden/indra/newview/llfloatertools.cpp index 4aa817e..4f8ed08 100644 --- a/linden/indra/newview/llfloatertools.cpp +++ b/linden/indra/newview/llfloatertools.cpp @@ -2,6 +2,8 @@ * @file llfloatertools.cpp * @brief The edit tools, including move, position, land, etc. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -314,6 +317,16 @@ BOOL LLFloaterTools::postBuild() mTab->setBorderVisible(FALSE); mTab->selectFirstTab(); } + + mStatusText["rotate"] = childGetText("status_rotate"); + mStatusText["scale"] = childGetText("status_scale"); + mStatusText["move"] = childGetText("status_move"); + mStatusText["modifyland"] = childGetText("status_modifyland"); + mStatusText["camera"] = childGetText("status_camera"); + mStatusText["grab"] = childGetText("status_grab"); + mStatusText["place"] = childGetText("status_place"); + mStatusText["selectland"] = childGetText("status_selectland"); + return TRUE; } @@ -415,9 +428,17 @@ LLFloaterTools::~LLFloaterTools() // children automatically deleted } -void LLFloaterTools::setStatusText(const LLString& text) +void LLFloaterTools::setStatusText(const std::string& text) { - mTextStatus->setText(text); + std::map::iterator iter = mStatusText.find(text); + if (iter != mStatusText.end()) + { + mTextStatus->setText(iter->second); + } + else + { + mTextStatus->setText(text); + } } void LLFloaterTools::refresh() @@ -490,6 +511,11 @@ void LLFloaterTools::updatePopup(LLCoordGL center, MASK mask) { return; } + + if ( isMinimized() ) + { // SL looks odd if we draw the tools while the window is minimized + return; + } // Focus buttons BOOL focus_visible = ( tool == gToolCamera ); @@ -579,27 +605,27 @@ void LLFloaterTools::updatePopup(LLCoordGL center, MASK mask) if (mComboGridMode) { - mComboGridMode ->setVisible( edit_visible ); + mComboGridMode->setVisible( edit_visible ); S32 index = mComboGridMode->getCurrentIndex(); mComboGridMode->removeall(); switch (mObjectSelection->getSelectType()) { case SELECT_TYPE_HUD: - mComboGridMode->add("Screen"); - mComboGridMode->add("Local"); - //mComboGridMode->add("Reference"); - break; + mComboGridMode->add(childGetText("grid_screen_text")); + mComboGridMode->add(childGetText("grid_local_text")); + //mComboGridMode->add(childGetText("grid_reference_text")); + break; case SELECT_TYPE_WORLD: - mComboGridMode->add("World"); - mComboGridMode->add("Local"); - mComboGridMode->add("Reference"); - break; + mComboGridMode->add(childGetText("grid_world_text")); + mComboGridMode->add(childGetText("grid_local_text")); + mComboGridMode->add(childGetText("grid_reference_text")); + break; case SELECT_TYPE_ATTACHMENT: - mComboGridMode->add("Attachment"); - mComboGridMode->add("Local"); - mComboGridMode->add("Reference"); - break; + mComboGridMode->add(childGetText("grid_attachment_text")); + mComboGridMode->add(childGetText("grid_local_text")); + mComboGridMode->add(childGetText("grid_reference_text")); + break; } mComboGridMode->setCurrentByIndex(index); diff --git a/linden/indra/newview/llfloatertools.h b/linden/indra/newview/llfloatertools.h index ae70a04..f56cdbe 100644 --- a/linden/indra/newview/llfloatertools.h +++ b/linden/indra/newview/llfloatertools.h @@ -2,6 +2,8 @@ * @file llfloatertools.h * @brief The edit tools, including move, position, land, etc. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERTOOLS_H @@ -94,7 +97,7 @@ public: void showMore(BOOL show_more); void showPanel(EInfoPanel panel); - void setStatusText(const LLString& text); + void setStatusText(const std::string& text); virtual void onFocusReceived(); static void setEditTool(void* data); void saveLastTool(); @@ -188,6 +191,8 @@ private: BOOL mDirty; S32 mSmallHeight; S32 mLargeHeight; + + std::map mStatusText; }; extern LLFloaterTools *gFloaterTools; diff --git a/linden/indra/newview/llfloatertopobjects.cpp b/linden/indra/newview/llfloatertopobjects.cpp index 53d00fc..e3f236b 100644 --- a/linden/indra/newview/llfloatertopobjects.cpp +++ b/linden/indra/newview/llfloatertopobjects.cpp @@ -2,6 +2,8 @@ * @file llfloatertopobjects.cpp * @brief Shows top colliders, top scripts, etc. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llfloatertopobjects.h b/linden/indra/newview/llfloatertopobjects.h index b539ebc..cab99c9 100644 --- a/linden/indra/newview/llfloatertopobjects.h +++ b/linden/indra/newview/llfloatertopobjects.h @@ -2,6 +2,8 @@ * @file llfloatertopobjects.h * @brief Shows top colliders or top scripts * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERTOPOBJECTS_H diff --git a/linden/indra/newview/llfloatertos.cpp b/linden/indra/newview/llfloatertos.cpp index 93aa3df..9e86c92 100644 --- a/linden/indra/newview/llfloatertos.cpp +++ b/linden/indra/newview/llfloatertos.cpp @@ -2,6 +2,8 @@ * @file llfloatertos.cpp * @brief Terms of Service Agreement dialog * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llfloatertos.h b/linden/indra/newview/llfloatertos.h index 5dfd939..e6c487d 100644 --- a/linden/indra/newview/llfloatertos.h +++ b/linden/indra/newview/llfloatertos.h @@ -2,6 +2,8 @@ * @file llfloatertos.h * @brief Terms of Service Agreement dialog * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERTOS_H diff --git a/linden/indra/newview/llfloatervoicewizard.cpp b/linden/indra/newview/llfloatervoicewizard.cpp index 69c7a9d..de11ab0 100644 --- a/linden/indra/newview/llfloatervoicewizard.cpp +++ b/linden/indra/newview/llfloatervoicewizard.cpp @@ -3,7 +3,9 @@ * @author Richard Nelson * @brief Voice communication set-up wizard * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -356,7 +359,7 @@ void LLPanelDeviceSettings::refresh() if(mCtrlInputDevices) { mCtrlInputDevices->removeall(); - mCtrlInputDevices->add( "Default", ADD_BOTTOM ); + mCtrlInputDevices->add( childGetText("default_text"), ADD_BOTTOM ); devices = gVoiceClient->getCaptureDevices(); for(iter=devices->begin(); iter != devices->end(); iter++) @@ -366,14 +369,14 @@ void LLPanelDeviceSettings::refresh() if(!mCtrlInputDevices->setSimple(mInputDevice)) { - mCtrlInputDevices->setSimple("Default"); + mCtrlInputDevices->setSimple(childGetText("default_text")); } } if(mCtrlOutputDevices) { mCtrlOutputDevices->removeall(); - mCtrlOutputDevices->add( "Default", ADD_BOTTOM ); + mCtrlOutputDevices->add( childGetText("default_text"), ADD_BOTTOM ); devices = gVoiceClient->getRenderDevices(); for(iter=devices->begin(); iter != devices->end(); iter++) @@ -383,7 +386,7 @@ void LLPanelDeviceSettings::refresh() if(!mCtrlOutputDevices->setSimple(mOutputDevice)) { - mCtrlOutputDevices->setSimple("Default"); + mCtrlOutputDevices->setSimple(childGetText("default_text")); } } mDevicesUpdated = TRUE; diff --git a/linden/indra/newview/llfloatervoicewizard.h b/linden/indra/newview/llfloatervoicewizard.h index 8e8c900..3c9792d 100644 --- a/linden/indra/newview/llfloatervoicewizard.h +++ b/linden/indra/newview/llfloatervoicewizard.h @@ -3,6 +3,8 @@ * @author Richard Nelson * @brief Voice communication set-up wizard * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFLOATERVOICEWIZARD_H diff --git a/linden/indra/newview/llfloaterworldmap.cpp b/linden/indra/newview/llfloaterworldmap.cpp index 237563f..bdb7f09 100644 --- a/linden/indra/newview/llfloaterworldmap.cpp +++ b/linden/indra/newview/llfloaterworldmap.cpp @@ -3,6 +3,8 @@ * @author James Cook, Tom Yedwab * @brief LLFloaterWorldMap class implementation * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /* @@ -259,7 +262,7 @@ BOOL LLFloaterWorldMap::postBuild() mCurZoomVal = log(gMapScale)/log(2.f); childSetValue("zoom slider", gMapScale); - setDefaultBtn(""); + setDefaultBtn(NULL); if ( gAgent.mAccess <= SIM_ACCESS_PG ) { @@ -295,20 +298,6 @@ void LLFloaterWorldMap::onClose(bool app_quitting) setVisible(FALSE); } -// Allow us to download landmarks quickly when map is shown -class LLLandmarkFetchDescendentsObserver : public LLInventoryFetchDescendentsObserver -{ -public: - virtual void done() - { - // We need to find landmarks in all folders, so get the main - // background download going. - gInventory.startBackgroundFetch(); - gInventory.removeObserver(this); - delete this; - } -}; - // static void LLFloaterWorldMap::show(void*, BOOL center_on_target) { @@ -348,7 +337,6 @@ void LLFloaterWorldMap::show(void*, BOOL center_on_target) LLFirstUse::useMap(); // Start speculative download of landmarks - LLInventoryFetchDescendentsObserver::folder_ref_t folders; LLUUID landmark_folder_id = gInventory.findCategoryUUIDForType(LLAssetType::AT_LANDMARK); gInventory.startBackgroundFetch(landmark_folder_id); @@ -1223,7 +1211,7 @@ void LLFloaterWorldMap::updateSearchEnabled( LLUICtrl* ctrl, void* userdata ) } else { - self->setDefaultBtn(""); + self->setDefaultBtn(NULL); } } diff --git a/linden/indra/newview/llfloaterworldmap.h b/linden/indra/newview/llfloaterworldmap.h index d2a4e6f..1757f86 100644 --- a/linden/indra/newview/llfloaterworldmap.h +++ b/linden/indra/newview/llfloaterworldmap.h @@ -2,6 +2,8 @@ * @file llfloaterworldmap.h * @brief LLFloaterWorldMap class definition * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /* diff --git a/linden/indra/newview/llfolderview.cpp b/linden/indra/newview/llfolderview.cpp index 3a58be9..a68b937 100644 --- a/linden/indra/newview/llfolderview.cpp +++ b/linden/indra/newview/llfolderview.cpp @@ -2,6 +2,8 @@ * @file llfolderview.cpp * @brief Implementation of the folder view collection of classes. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -2944,12 +2947,10 @@ BOOL LLFolderView::changeSelection(LLFolderViewItem* selection, BOOL selected) if(selected && !on_list) { - mNumDescendantsSelected++; addToSelectionList(selection); } if(!selected && on_list) { - mNumDescendantsSelected--; removeFromSelectionList(selection); } @@ -3192,18 +3193,18 @@ void LLFolderView::draw() if (hasVisibleChildren() || getShowFolderState() == LLInventoryFilter::SHOW_ALL_FOLDERS) { - setStatusText(""); + mStatusText.clear(); } else { if (gInventory.backgroundFetchActive() || mCompletedFilterGeneration < mFilter.getMinRequiredGeneration()) { - setStatusText("Searching..."); + mStatusText = "Searching..."; // *TODO:translate sFont->renderUTF8(mStatusText, 0, 2, 1, LLColor4::white, LLFontGL::LEFT, LLFontGL::TOP, LLFontGL::NORMAL, S32_MAX, S32_MAX, NULL, FALSE ); } else { - setStatusText("No matching items found in inventory."); + mStatusText = "No matching items found in inventory."; // *TODO:translate sFont->renderUTF8(mStatusText, 0, 2, 1, LLColor4::white, LLFontGL::LEFT, LLFontGL::TOP, LLFontGL::NORMAL, S32_MAX, S32_MAX, NULL, FALSE ); } } @@ -3677,6 +3678,14 @@ BOOL LLFolderView::handleKeyHere( KEY key, MASK mask, BOOL called_from_parent ) { BOOL handled = FALSE; + // SL-51858: Key presses are not being passed to the Popup menu. + // A proper fix is non-trivial so instead just close the menu. + LLMenuGL* menu = (LLMenuGL*)LLView::getViewByHandle(mPopupMenuHandle); + if (menu->isOpen()) + { + LLMenuGL::sMenuContainer->hideMenus(); + } + LLView *item = NULL; if (getChildCount() > 0) { diff --git a/linden/indra/newview/llfolderview.h b/linden/indra/newview/llfolderview.h index 9336ec3..dd0dd21 100644 --- a/linden/indra/newview/llfolderview.h +++ b/linden/indra/newview/llfolderview.h @@ -2,6 +2,8 @@ * @file llfolderview.h * @brief Definition of the folder view collection of classes. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /** @@ -481,8 +484,6 @@ public: BOOL isDescendantOf( const LLFolderViewFolder* potential_ancestor ); S32 getIndentation() { return mIndentation; } - virtual void setStatusText(const LLString& text) { mStatusText = text; } - virtual BOOL potentiallyVisible(); // do we know for a fact that this item has been filtered out? virtual BOOL getFiltered(); diff --git a/linden/indra/newview/llfollowcam.cpp b/linden/indra/newview/llfollowcam.cpp index b18b0d2..a370554 100644 --- a/linden/indra/newview/llfollowcam.cpp +++ b/linden/indra/newview/llfollowcam.cpp @@ -3,6 +3,8 @@ * @author Jeffrey Ventrella * @brief LLFollowCam class implementation * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llfollowcam.h b/linden/indra/newview/llfollowcam.h index a199dbb..ab8ffb1 100644 --- a/linden/indra/newview/llfollowcam.h +++ b/linden/indra/newview/llfollowcam.h @@ -3,6 +3,8 @@ * @author Jeffrey Ventrella * @brief LLFollowCam class definition * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //-------------------------------------------------------------------- diff --git a/linden/indra/newview/llframestats.cpp b/linden/indra/newview/llframestats.cpp index 9ae7667..a7bff15 100644 --- a/linden/indra/newview/llframestats.cpp +++ b/linden/indra/newview/llframestats.cpp @@ -2,6 +2,8 @@ * @file llframestats.cpp * @brief LLFrameStats class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,11 +26,11 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" -#include #include "llframestats.h" #include "v4color.h" #include "pipeline.h" diff --git a/linden/indra/newview/llframestats.h b/linden/indra/newview/llframestats.h index 2f83061..95ff4bc 100644 --- a/linden/indra/newview/llframestats.h +++ b/linden/indra/newview/llframestats.h @@ -2,6 +2,8 @@ * @file llframestats.h * @brief LLFrameStats class definition * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFRAMESTATS_H diff --git a/linden/indra/newview/llframestatview.cpp b/linden/indra/newview/llframestatview.cpp index c489caa..aa6c609 100644 --- a/linden/indra/newview/llframestatview.cpp +++ b/linden/indra/newview/llframestatview.cpp @@ -2,6 +2,8 @@ * @file llframestatview.cpp * @brief LLFrameStatView class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llframestatview.h b/linden/indra/newview/llframestatview.h index 7bcc041..3bf6a37 100644 --- a/linden/indra/newview/llframestatview.h +++ b/linden/indra/newview/llframestatview.h @@ -2,6 +2,8 @@ * @file llframestatview.h * @brief LLFrameStatView class definition * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLFRAMESTATVIEW_H diff --git a/linden/indra/newview/llgenepool.cpp b/linden/indra/newview/llgenepool.cpp index 40dd5cd..c66b154 100644 --- a/linden/indra/newview/llgenepool.cpp +++ b/linden/indra/newview/llgenepool.cpp @@ -2,6 +2,8 @@ * @file llgenepool.cpp * @brief LLGenePool class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llgenepool.h b/linden/indra/newview/llgenepool.h index dfe54bb..24fcc05 100644 --- a/linden/indra/newview/llgenepool.h +++ b/linden/indra/newview/llgenepool.h @@ -2,6 +2,8 @@ * @file llgenepool.h * @brief LLGenePool class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLGENEPOOL_H diff --git a/linden/indra/newview/llgesturemgr.cpp b/linden/indra/newview/llgesturemgr.cpp index 9b8f2c8..3e17ecf 100644 --- a/linden/indra/newview/llgesturemgr.cpp +++ b/linden/indra/newview/llgesturemgr.cpp @@ -2,6 +2,8 @@ * @file llgesturemgr.cpp * @brief Manager for playing gestures on the viewer * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -436,6 +439,19 @@ void LLGestureManager::replaceGesture(const LLUUID& item_id, LLMultiGesture* new notifyObservers(); } +void LLGestureManager::replaceGesture(const LLUUID& item_id, const LLUUID& new_asset_id) +{ + item_map_t::iterator it = gGestureManager.mActive.find(item_id); + if (it == mActive.end()) + { + llwarns << "replaceGesture for inactive gesture " << item_id << llendl; + return; + } + + // mActive owns this gesture pointer, so clean up memory. + LLMultiGesture* gesture = (*it).second; + gGestureManager.replaceGesture(item_id, gesture, new_asset_id); +} void LLGestureManager::playGesture(LLMultiGesture* gesture) { diff --git a/linden/indra/newview/llgesturemgr.h b/linden/indra/newview/llgesturemgr.h index 92b484a..59790f8 100644 --- a/linden/indra/newview/llgesturemgr.h +++ b/linden/indra/newview/llgesturemgr.h @@ -2,6 +2,8 @@ * @file llgesturemgr.h * @brief Manager for playing gestures on the viewer * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLGESTUREMGR_H @@ -70,6 +73,7 @@ public: // If you change a gesture, you need to build a new multigesture // and call this method. void replaceGesture(const LLUUID& item_id, LLMultiGesture* new_gesture, const LLUUID& asset_id); + void replaceGesture(const LLUUID& item_id, const LLUUID& asset_id); // Load gesture into in-memory active form. // Can be called even if the inventory item isn't loaded yet. diff --git a/linden/indra/newview/llgivemoney.cpp b/linden/indra/newview/llgivemoney.cpp index 9ae6c67..df902fb 100644 --- a/linden/indra/newview/llgivemoney.cpp +++ b/linden/indra/newview/llgivemoney.cpp @@ -3,6 +3,8 @@ * @author Aaron Brashears, Kelly Washington, James Cook * @brief Implementation of the LLFloaterPay class. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -239,8 +242,8 @@ void LLFloaterPay::processPayPriceReply(LLMessageSystem* msg, void **userdata) LLString button_str; gResMgr->getMonetaryString( button_str, pay_button ); - self->mQuickPayButton[i]->setLabelSelected(button_str.c_str()); - self->mQuickPayButton[i]->setLabelUnselected(button_str.c_str()); + self->mQuickPayButton[i]->setLabelSelected(button_str); + self->mQuickPayButton[i]->setLabelUnselected(button_str); self->mQuickPayButton[i]->setVisible(TRUE); self->mQuickPayInfo[i]->mAmount = pay_button; self->childSetVisible("fastpay text",TRUE); @@ -402,8 +405,8 @@ void LLFloaterPay::onCacheOwnerName(const LLUUID& owner_id, self->childSetVisible("payee_resident",true); } - self->childSetTextArg("payee_name", "[FIRST]", firstname); - self->childSetTextArg("payee_name", "[LAST]", lastname); + self->childSetTextArg("payee_name", "[FIRST]", LLString(firstname)); + self->childSetTextArg("payee_name", "[LAST]", LLString(lastname)); } // static @@ -486,3 +489,4 @@ void LLFloaterPay::give(S32 amount) /// Local function definitions ///---------------------------------------------------------------------------- + diff --git a/linden/indra/newview/llgivemoney.h b/linden/indra/newview/llgivemoney.h index f2b5a9a..c587424 100644 --- a/linden/indra/newview/llgivemoney.h +++ b/linden/indra/newview/llgivemoney.h @@ -2,6 +2,8 @@ * @file llgivemoney.h * @brief LLGiveMoney class header file * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLGIVEMONEY_H diff --git a/linden/indra/newview/llglsandbox.cpp b/linden/indra/newview/llglsandbox.cpp index 81806dc..da3f7aa 100644 --- a/linden/indra/newview/llglsandbox.cpp +++ b/linden/indra/newview/llglsandbox.cpp @@ -2,6 +2,8 @@ * @file llglsandbox.cpp * @brief GL functionality access * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /** @@ -248,35 +251,35 @@ void LLToolSelectRect::handleRectangleSelection(S32 x, S32 y, MASK mask) if (shrink_selection) { - LLObjectSelectionHandle highlighted_objects = gSelectMgr->getHighlightedObjects(); - - for (LLViewerObject* vobjp = highlighted_objects->getFirstObject(); - vobjp; - vobjp = highlighted_objects->getNextObject()) + struct f : public LLSelectedObjectFunctor + { + virtual bool apply(LLViewerObject* vobjp) { LLDrawable* drawable = vobjp->mDrawable; if (!drawable || vobjp->getPCode() != LL_PCODE_VOLUME || vobjp->isAttachment()) { - continue; + return true; } - S32 result = gCamera->sphereInFrustum(drawable->getPositionAgent(), drawable->getRadius()); switch (result) { - case 0: + case 0: gSelectMgr->unhighlightObjectOnly(vobjp); break; - case 1: + case 1: // check vertices if (!gCamera->areVertsVisible(vobjp, LLSelectMgr::sRectSelectInclusive)) { gSelectMgr->unhighlightObjectOnly(vobjp); } break; - default: + default: break; } + return true; } + } func; + gSelectMgr->getHighlightedObjects()->applyToObjects(&func); } if (grow_selection) diff --git a/linden/indra/newview/llglslshader.cpp b/linden/indra/newview/llglslshader.cpp index 0a7ec4a..aa65eab 100644 --- a/linden/indra/newview/llglslshader.cpp +++ b/linden/indra/newview/llglslshader.cpp @@ -2,6 +2,8 @@ * @file llglslshader.cpp * @brief GLSL helper functions and state. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llglslshader.h b/linden/indra/newview/llglslshader.h index bbf91a8..e4023b8 100644 --- a/linden/indra/newview/llglslshader.h +++ b/linden/indra/newview/llglslshader.h @@ -2,6 +2,8 @@ * @file llglslshader.h * @brief GLSL shader wrappers * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLGLSLSHADER_H diff --git a/linden/indra/newview/llgroupmgr.cpp b/linden/indra/newview/llgroupmgr.cpp index 8e49749..d1116b6 100644 --- a/linden/indra/newview/llgroupmgr.cpp +++ b/linden/indra/newview/llgroupmgr.cpp @@ -2,6 +2,8 @@ * @file llgroupmgr.cpp * @brief LLGroupMgr class implementation * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /** @@ -215,6 +218,7 @@ LLGroupMgrGroupData::LLGroupMgrGroupData(const LLUUID& id) : mOpenEnrollment(FALSE), mMembershipFee(0), mAllowPublish(FALSE), + mListInProfile(FALSE), mMaturePublish(FALSE), mChanged(FALSE), mMemberCount(0), @@ -776,7 +780,10 @@ void LLGroupMgr::removeObserver(LLGroupMgrObserver* observer) mObservers.erase(it); break; } - ++it; + else + { + ++it; + } } } @@ -1260,6 +1267,7 @@ void LLGroupMgr::processCreateGroupReply(LLMessageSystem* msg, void ** data) // This isn't actually too bad because real data will come down in 2 or 3 miliseconds and replace this. LLGroupData gd; gd.mAcceptNotices = TRUE; + gd.mListInProfile = TRUE; gd.mContribution = 0; gd.mID = group_id; gd.mName = "new group"; @@ -1272,7 +1280,7 @@ void LLGroupMgr::processCreateGroupReply(LLMessageSystem* msg, void ** data) } else { - // XUI:translate + // *TODO:translate LLString::format_map_t args; args["[MESSAGE]"] = message; gViewerWindow->alertXml("UnableToCreateGroup", args); @@ -1282,6 +1290,7 @@ void LLGroupMgr::processCreateGroupReply(LLMessageSystem* msg, void ** data) LLGroupMgrGroupData* LLGroupMgr::createGroupData(const LLUUID& id) { LLGroupMgrGroupData* group_datap; + group_iter existing_group = gGroupMgr->mGroups.find(id); if (existing_group == gGroupMgr->mGroups.end()) { @@ -1315,7 +1324,6 @@ void LLGroupMgr::notifyObservers(LLGroupChange gc) void LLGroupMgr::addGroup(LLGroupMgrGroupData* group_datap) { - mGroups[group_datap->getID()] = group_datap; if (mGroups.size() > MAX_CACHED_GROUPS) { // get rid of groups that aren't observed @@ -1325,8 +1333,8 @@ void LLGroupMgr::addGroup(LLGroupMgrGroupData* group_datap) if (oi == mObservers.end()) { // not observed - LLGroupMgrGroupData* group_datap = gi->second; - delete group_datap; + LLGroupMgrGroupData* unobserved_groupp = gi->second; + delete unobserved_groupp; mGroups.erase(gi++); } else @@ -1335,6 +1343,7 @@ void LLGroupMgr::addGroup(LLGroupMgrGroupData* group_datap) } } } + mGroups[group_datap->getID()] = group_datap; } @@ -1848,3 +1857,4 @@ void LLGroupMgr::debugClearAllGroups(void*) LLGroupMgr::parseRoleActions("role_actions.xml"); } + diff --git a/linden/indra/newview/llgroupmgr.h b/linden/indra/newview/llgroupmgr.h index bc4fa71..76040f9 100644 --- a/linden/indra/newview/llgroupmgr.h +++ b/linden/indra/newview/llgroupmgr.h @@ -2,6 +2,8 @@ * @file llgroupmgr.h * @brief Manager for aggregating all client knowledge for specific groups * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLGROUPMGR_H @@ -252,6 +255,7 @@ public: BOOL mOpenEnrollment; S32 mMembershipFee; BOOL mAllowPublish; + BOOL mListInProfile; BOOL mMaturePublish; BOOL mChanged; S32 mMemberCount; diff --git a/linden/indra/newview/llgroupnotify.cpp b/linden/indra/newview/llgroupnotify.cpp index 95d4dbf..8a88165 100644 --- a/linden/indra/newview/llgroupnotify.cpp +++ b/linden/indra/newview/llgroupnotify.cpp @@ -2,6 +2,8 @@ * @file llgroupnotify.cpp * @brief Non-blocking notification that doesn't take keyboard focus. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llgroupnotify.h b/linden/indra/newview/llgroupnotify.h index d465181..34b4dda 100644 --- a/linden/indra/newview/llgroupnotify.h +++ b/linden/indra/newview/llgroupnotify.h @@ -2,6 +2,8 @@ * @file llgroupnotify.h * @brief Non-blocking notification that doesn't take keyboard focus. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLGROUPNOTIFY_H diff --git a/linden/indra/newview/llhippo.cpp b/linden/indra/newview/llhippo.cpp index 9d4b52b..22f7cb5 100644 --- a/linden/indra/newview/llhippo.cpp +++ b/linden/indra/newview/llhippo.cpp @@ -2,6 +2,8 @@ * @file llhippo.cpp * @brief Create a bug for our users to find * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llhippo.h b/linden/indra/newview/llhippo.h index ee37dbe..4d064fb 100644 --- a/linden/indra/newview/llhippo.h +++ b/linden/indra/newview/llhippo.h @@ -2,6 +2,8 @@ * @file llhippo.h * @brief Implement a "bug" for our users to find. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLHIPPO_H diff --git a/linden/indra/newview/llhoverview.cpp b/linden/indra/newview/llhoverview.cpp index c7f1736..3804e4d 100644 --- a/linden/indra/newview/llhoverview.cpp +++ b/linden/indra/newview/llhoverview.cpp @@ -2,6 +2,8 @@ * @file llhoverview.cpp * @brief LLHoverView class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llhoverview.h b/linden/indra/newview/llhoverview.h index a2b624c..b76e074 100644 --- a/linden/indra/newview/llhoverview.h +++ b/linden/indra/newview/llhoverview.h @@ -2,6 +2,8 @@ * @file llhoverview.h * @brief LLHoverView class definition * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLHOVERVIEW_H diff --git a/linden/indra/newview/llhudconnector.cpp b/linden/indra/newview/llhudconnector.cpp index 8739917..e738a86 100644 --- a/linden/indra/newview/llhudconnector.cpp +++ b/linden/indra/newview/llhudconnector.cpp @@ -2,6 +2,8 @@ * @file llhudconnector.cpp * @brief LLHUDConnector class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llhudconnector.h b/linden/indra/newview/llhudconnector.h index 4b7bf77..264a545 100644 --- a/linden/indra/newview/llhudconnector.h +++ b/linden/indra/newview/llhudconnector.h @@ -2,6 +2,8 @@ * @file llhudconnector.h * @brief LLHUDConnector class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLHUDCONNECTOR_H diff --git a/linden/indra/newview/llhudeffect.cpp b/linden/indra/newview/llhudeffect.cpp index 96035c6..1385141 100644 --- a/linden/indra/newview/llhudeffect.cpp +++ b/linden/indra/newview/llhudeffect.cpp @@ -2,6 +2,8 @@ * @file llhudeffect.cpp * @brief LLHUDEffect class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llhudeffect.h b/linden/indra/newview/llhudeffect.h index 98a7553..c81fd60 100644 --- a/linden/indra/newview/llhudeffect.h +++ b/linden/indra/newview/llhudeffect.h @@ -2,6 +2,8 @@ * @file llhudeffect.h * @brief LLHUDEffect class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLHUDEFFECT_H diff --git a/linden/indra/newview/llhudeffectbeam.cpp b/linden/indra/newview/llhudeffectbeam.cpp index 4b74f88..22aa7be 100644 --- a/linden/indra/newview/llhudeffectbeam.cpp +++ b/linden/indra/newview/llhudeffectbeam.cpp @@ -2,6 +2,8 @@ * @file llhudeffectbeam.cpp * @brief LLHUDEffectBeam class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llhudeffectbeam.h b/linden/indra/newview/llhudeffectbeam.h index de6d18d..f281b4f 100644 --- a/linden/indra/newview/llhudeffectbeam.h +++ b/linden/indra/newview/llhudeffectbeam.h @@ -2,6 +2,8 @@ * @file llhudeffectbeam.h * @brief LLHUDEffectBeam class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLHUDEFFECTBEAM_H diff --git a/linden/indra/newview/llhudeffectlookat.cpp b/linden/indra/newview/llhudeffectlookat.cpp index 6922f29..16c7714 100644 --- a/linden/indra/newview/llhudeffectlookat.cpp +++ b/linden/indra/newview/llhudeffectlookat.cpp @@ -2,6 +2,8 @@ * @file llhudeffectlookat.cpp * @brief LLHUDEffectLookAt class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llhudeffectlookat.h b/linden/indra/newview/llhudeffectlookat.h index fdb3432..4295078 100644 --- a/linden/indra/newview/llhudeffectlookat.h +++ b/linden/indra/newview/llhudeffectlookat.h @@ -2,6 +2,8 @@ * @file llhudeffectlookat.h * @brief LLHUDEffectLookAt class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLHUDEFFECTLOOKAT_H diff --git a/linden/indra/newview/llhudeffectpointat.cpp b/linden/indra/newview/llhudeffectpointat.cpp index 7218642..fbb5ba5 100644 --- a/linden/indra/newview/llhudeffectpointat.cpp +++ b/linden/indra/newview/llhudeffectpointat.cpp @@ -2,6 +2,8 @@ * @file llhudeffectpointat.cpp * @brief LLHUDEffectPointAt class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llhudeffectpointat.h b/linden/indra/newview/llhudeffectpointat.h index aba4dc8..3d1ded6 100644 --- a/linden/indra/newview/llhudeffectpointat.h +++ b/linden/indra/newview/llhudeffectpointat.h @@ -2,6 +2,8 @@ * @file llhudeffectpointat.h * @brief LLHUDEffectPointAt class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLHUDEFFECTPOINTAT_H diff --git a/linden/indra/newview/llhudeffecttrail.cpp b/linden/indra/newview/llhudeffecttrail.cpp index 7cfc3e1..dd2c155 100644 --- a/linden/indra/newview/llhudeffecttrail.cpp +++ b/linden/indra/newview/llhudeffecttrail.cpp @@ -2,6 +2,8 @@ * @file llhudeffecttrail.cpp * @brief LLHUDEffectSpiral class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llhudeffecttrail.h b/linden/indra/newview/llhudeffecttrail.h index d14d000..a3efc27 100644 --- a/linden/indra/newview/llhudeffecttrail.h +++ b/linden/indra/newview/llhudeffecttrail.h @@ -2,6 +2,8 @@ * @file llhudeffecttrail.h * @brief LLHUDEffectSpiral class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLHUDEFFECTTRAIL_H diff --git a/linden/indra/newview/llhudicon.cpp b/linden/indra/newview/llhudicon.cpp index 15988fa..229228f 100644 --- a/linden/indra/newview/llhudicon.cpp +++ b/linden/indra/newview/llhudicon.cpp @@ -2,6 +2,8 @@ * @file llhudicon.cpp * @brief LLHUDIcon class implementation * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llhudicon.h b/linden/indra/newview/llhudicon.h index 7f8b435..7fa53cb 100644 --- a/linden/indra/newview/llhudicon.h +++ b/linden/indra/newview/llhudicon.h @@ -2,6 +2,8 @@ * @file llhudicon.h * @brief LLHUDIcon class definition * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLHUDICON_H diff --git a/linden/indra/newview/llhudmanager.cpp b/linden/indra/newview/llhudmanager.cpp index d06b84b..c08e955 100644 --- a/linden/indra/newview/llhudmanager.cpp +++ b/linden/indra/newview/llhudmanager.cpp @@ -2,6 +2,8 @@ * @file llhudmanager.cpp * @brief LLHUDManager class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llhudmanager.h b/linden/indra/newview/llhudmanager.h index 44c8ed5..2f8c1a1 100644 --- a/linden/indra/newview/llhudmanager.h +++ b/linden/indra/newview/llhudmanager.h @@ -2,6 +2,8 @@ * @file llhudmanager.h * @brief LLHUDManager class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLHUDMANAGER_H diff --git a/linden/indra/newview/llhudobject.cpp b/linden/indra/newview/llhudobject.cpp index 35e6d94..6271f0f 100644 --- a/linden/indra/newview/llhudobject.cpp +++ b/linden/indra/newview/llhudobject.cpp @@ -2,6 +2,8 @@ * @file llhudobject.cpp * @brief LLHUDObject class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // llhudobject.cpp diff --git a/linden/indra/newview/llhudobject.h b/linden/indra/newview/llhudobject.h index 7b74165..5e2c300 100644 --- a/linden/indra/newview/llhudobject.h +++ b/linden/indra/newview/llhudobject.h @@ -2,6 +2,8 @@ * @file llhudobject.h * @brief LLHUDObject class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLHUDOBJECT_H diff --git a/linden/indra/newview/llhudrender.cpp b/linden/indra/newview/llhudrender.cpp index f85638e..df1fdf1 100644 --- a/linden/indra/newview/llhudrender.cpp +++ b/linden/indra/newview/llhudrender.cpp @@ -2,6 +2,8 @@ * @file llhudrender.cpp * @brief LLHUDRender class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llhudrender.h b/linden/indra/newview/llhudrender.h index 1233f46..648e99b 100644 --- a/linden/indra/newview/llhudrender.h +++ b/linden/indra/newview/llhudrender.h @@ -2,6 +2,8 @@ * @file llhudrender.h * @brief LLHUDRender class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLHUDRENDER_H diff --git a/linden/indra/newview/llhudtext.cpp b/linden/indra/newview/llhudtext.cpp index 20bf486..1ebe813 100644 --- a/linden/indra/newview/llhudtext.cpp +++ b/linden/indra/newview/llhudtext.cpp @@ -2,6 +2,8 @@ * @file llhudtext.cpp * @brief LLHUDText class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llhudtext.h b/linden/indra/newview/llhudtext.h index bd6988b..75dc43c 100644 --- a/linden/indra/newview/llhudtext.h +++ b/linden/indra/newview/llhudtext.h @@ -2,6 +2,8 @@ * @file llhudtext.h * @brief LLHUDText class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLHUDTEXT_H diff --git a/linden/indra/newview/llhudview.cpp b/linden/indra/newview/llhudview.cpp index 2ce9172..e40e84b 100644 --- a/linden/indra/newview/llhudview.cpp +++ b/linden/indra/newview/llhudview.cpp @@ -2,6 +2,8 @@ * @file llhudview.cpp * @brief 2D HUD overlay * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llhudview.h b/linden/indra/newview/llhudview.h index d958f9c..b2353ad 100644 --- a/linden/indra/newview/llhudview.h +++ b/linden/indra/newview/llhudview.h @@ -2,6 +2,8 @@ * @file llhudview.h * @brief 2D HUD overlay * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLHUDVIEW_H diff --git a/linden/indra/newview/llimpanel.cpp b/linden/indra/newview/llimpanel.cpp index 2529d04..3a947bc 100644 --- a/linden/indra/newview/llimpanel.cpp +++ b/linden/indra/newview/llimpanel.cpp @@ -2,6 +2,8 @@ * @file llimpanel.cpp * @brief LLIMPanel class definition * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -934,7 +937,7 @@ void LLFloaterIMPanel::init(const LLString& session_label) session_start.setArg("[NAME]", getTitle()); mSessionStartMsgPos = - mHistoryEditor->getText().length(); + mHistoryEditor->getWText().length(); addHistoryLine( session_start, @@ -1634,7 +1637,7 @@ void LLFloaterIMPanel::sendMsg() gViewerStats->incStat(LLViewerStats::ST_IM_COUNT); } - mInputEditor->setText(""); + mInputEditor->setText(LLString::null); // Don't need to actually send the typing stop message, the other // client will infer it from receiving the message. @@ -1666,7 +1669,7 @@ void LLFloaterIMPanel::sessionInitReplyReceived(const LLUUID& session_id) //we assume the history editor hasn't moved at all since //we added the starting session message //so, we count how many characters to remove - S32 chars_to_remove = mHistoryEditor->getText().length() - + S32 chars_to_remove = mHistoryEditor->getWText().length() - mSessionStartMsgPos; mHistoryEditor->removeTextFromEnd(chars_to_remove); @@ -1764,7 +1767,7 @@ void LLFloaterIMPanel::addTypingIndicator(const std::string &name) // we may have lost a "stop-typing" packet, don't add it twice if (!mOtherTyping) { - mTypingLineStartIndex = mHistoryEditor->getText().length(); + mTypingLineStartIndex = mHistoryEditor->getWText().length(); LLUIString typing_start = sTypingStartString; typing_start.setArg("[NAME]", name); addHistoryLine(typing_start, gSavedSettings.getColor4("SystemChatColor"), false); @@ -1784,7 +1787,7 @@ void LLFloaterIMPanel::removeTypingIndicator(const LLIMInfo* im_info) // Must do this first, otherwise addHistoryLine calls us again. mOtherTyping = FALSE; - S32 chars_to_remove = mHistoryEditor->getText().length() - mTypingLineStartIndex; + S32 chars_to_remove = mHistoryEditor->getWText().length() - mTypingLineStartIndex; mHistoryEditor->removeTextFromEnd(chars_to_remove); if (im_info) { diff --git a/linden/indra/newview/llimpanel.h b/linden/indra/newview/llimpanel.h index 525f868..631dc5c 100644 --- a/linden/indra/newview/llimpanel.h +++ b/linden/indra/newview/llimpanel.h @@ -2,6 +2,8 @@ * @file llimpanel.h * @brief LLIMPanel class definition * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_IMPANEL_H diff --git a/linden/indra/newview/llimview.cpp b/linden/indra/newview/llimview.cpp index 9df51b9..dee1ed2 100644 --- a/linden/indra/newview/llimview.cpp +++ b/linden/indra/newview/llimview.cpp @@ -2,6 +2,8 @@ * @file LLIMMgr.cpp * @brief Container for Instant Messaging * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -164,7 +167,8 @@ BOOL LLFloaterIM::postBuild() sErrorStringsMap["no_user_911"] = getFormattedUIString("user_no_help"); - sEventStringsMap["add"] = childGetText("add_session_event"); + sEventStringsMap["add"] = + getFormattedUIString("add_session_event"); sEventStringsMap["message"] = getFormattedUIString("message_session_event"); @@ -385,7 +389,7 @@ void LLIMMgr::addMessage( // when answering questions. if(gAgent.isGodlike()) { - // XUI:translate + // *TODO:translate (low priority, god ability) std::ostringstream bonus_info; bonus_info << "*** parent estate: " << parent_estate_id diff --git a/linden/indra/newview/llimview.h b/linden/indra/newview/llimview.h index ca3ef5f..5f7829c 100644 --- a/linden/indra/newview/llimview.h +++ b/linden/indra/newview/llimview.h @@ -2,6 +2,8 @@ * @file LLIMMgr.h * @brief Container for Instant Messaging * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLIMVIEW_H diff --git a/linden/indra/newview/llinventoryactions.cpp b/linden/indra/newview/llinventoryactions.cpp index c1b85e1..fba3ace 100644 --- a/linden/indra/newview/llinventoryactions.cpp +++ b/linden/indra/newview/llinventoryactions.cpp @@ -2,6 +2,8 @@ * @file llinventoryactions.cpp * @brief Implementation of the actions associated with menu items. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -82,6 +85,10 @@ #include "llvieweruictrlfactory.h" #include "llselectmgr.h" +const char* NEW_LSL_NAME = "New Script"; // *TODO:Translate? (probably not) +const char* NEW_NOTECARD_NAME = "New Note"; // *TODO:Translate? (probably not) +const char* NEW_GESTURE_NAME = "New Gesture"; // *TODO:Translate? (probably not) + typedef LLMemberListener object_inventory_listener_t; typedef LLMemberListener inventory_listener_t; typedef LLMemberListener inventory_panel_listener_t; diff --git a/linden/indra/newview/llinventorybridge.cpp b/linden/indra/newview/llinventorybridge.cpp index f8baf46..505364f 100644 --- a/linden/indra/newview/llinventorybridge.cpp +++ b/linden/indra/newview/llinventorybridge.cpp @@ -2,6 +2,8 @@ * @file llinventorybridge.cpp * @brief Implementation of the Inventory-Folder-View-Bridge classes. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -109,13 +112,6 @@ void remove_inventory_category_from_avatar_step2( BOOL proceed, void* userdata); void move_task_inventory_callback(S32 option, void* user_data); void confirm_replace_attachment_rez(S32 option, void* user_data); -// TomY XUI: translate -const char* FIND_HINT = "Start typing to select an item by name"; -const char* NAME_SEARCH_DESC = "Find items whose name contains (leave blank for all):"; -const char* NEW_LSL_NAME = "New Script"; -const char* NEW_NOTECARD_NAME = "New Note"; -const char* NEW_GESTURE_NAME = "New Gesture"; - const char* ICON_NAME[ICON_NAME_COUNT] = { "inv_item_texture.tga", @@ -1788,8 +1784,14 @@ void LLFolderBridge::folderOptionsMenu() checkFolderForContentsOfType(model, is_gesture) ) { mItems.push_back("Folder Wearables Separator"); - mItems.push_back("Add To Outfit"); - mItems.push_back("Replace Outfit"); + + // Only enable add/replace outfit for non-default folders. + const LLInventoryCategory* category = model->getCategory(mUUID); + if (!category || (LLAssetType::AT_NONE == category->getPreferredType())) + { + mItems.push_back("Add To Outfit"); + mItems.push_back("Replace Outfit"); + } mItems.push_back("Take Off Items"); } hideContextEntries(*mMenu, mItems, disabled_items); @@ -4252,7 +4254,6 @@ void LLWearableBridge::buildContextMenu(LLMenuGL& menu, U32 flags) no_open = (item->getType() == LLAssetType::AT_CLOTHING) || (item->getType() == LLAssetType::AT_BODYPART); } - if (!no_open) { items.push_back("Open"); diff --git a/linden/indra/newview/llinventorybridge.h b/linden/indra/newview/llinventorybridge.h index 1269fa2..8c2eb2b 100644 --- a/linden/indra/newview/llinventorybridge.h +++ b/linden/indra/newview/llinventorybridge.h @@ -2,6 +2,8 @@ * @file llinventorybridge.h * @brief Implementation of the Inventory-Folder-View-Bridge classes. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llfloaterproperties.h" diff --git a/linden/indra/newview/llinventoryclipboard.cpp b/linden/indra/newview/llinventoryclipboard.cpp index da067ad..c3c8a29 100644 --- a/linden/indra/newview/llinventoryclipboard.cpp +++ b/linden/indra/newview/llinventoryclipboard.cpp @@ -2,6 +2,8 @@ * @file llinventoryclipboard.cpp * @brief LLInventoryClipboard class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llinventoryclipboard.h b/linden/indra/newview/llinventoryclipboard.h index e706269..c09ce96 100644 --- a/linden/indra/newview/llinventoryclipboard.h +++ b/linden/indra/newview/llinventoryclipboard.h @@ -2,6 +2,8 @@ * @file llinventoryclipboard.h * @brief LLInventoryClipboard class header file * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLINVENTORYCLIPBOARD_H diff --git a/linden/indra/newview/llinventorymodel.cpp b/linden/indra/newview/llinventorymodel.cpp index 9df8fa4..aa90538 100644 --- a/linden/indra/newview/llinventorymodel.cpp +++ b/linden/indra/newview/llinventorymodel.cpp @@ -2,6 +2,8 @@ * @file llinventorymodel.cpp * @brief Implementation of the inventory model used to track agent inventory. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -172,7 +175,8 @@ LLInventoryModel gInventory; // Default constructor LLInventoryModel::LLInventoryModel() : mModifyMask(LLInventoryObserver::ALL), - mLastItem(NULL) + mLastItem(NULL), + mIsAgentInvUsable(false) { } @@ -289,13 +293,9 @@ void LLInventoryModel::getDirectDescendentsOf(const LLUUID& cat_id, LLUUID LLInventoryModel::findCategoryUUIDForType(LLAssetType::EType t) { LLUUID rv = findCatUUID(t); - if(rv.isNull()) + if(rv.isNull() && isInventoryUsable()) { - rv = gAgent.getInventoryRootID(); - if(rv.notNull()) - { - rv = createNewCategory(rv, t, NULL); - } + rv = createNewCategory(rv, t, NULL); } return rv; } @@ -329,7 +329,7 @@ LLUUID LLInventoryModel::findCatUUID(LLAssetType::EType preferred_type) } // Convenience function to create a new category. You could call -// updateCatgory() with a newly generated UUID category, but this +// updateCategory() with a newly generated UUID category, but this // version will take care of details like what the name should be // based on preferred type. Returns the UUID of the new category. LLUUID LLInventoryModel::createNewCategory(const LLUUID& parent_id, @@ -337,6 +337,12 @@ LLUUID LLInventoryModel::createNewCategory(const LLUUID& parent_id, const LLString& pname) { LLUUID id; + if(!isInventoryUsable()) + { + llwarns << "Inventory is broken." << llendl; + return id; + } + id.generate(); LLString name = pname; if(!pname.empty()) @@ -470,6 +476,16 @@ void LLInventoryModel::appendPath(const LLUUID& id, LLString& path) path.append(temp); } +bool LLInventoryModel::isInventoryUsable() +{ + bool result = false; + if(gAgent.getInventoryRootID().notNull() && mIsAgentInvUsable) + { + result = true; + } + return result; +} + // Calling this method with an inventory item will either change an // existing item with a matching item_id, or will add the item to the // current inventory. @@ -480,6 +496,13 @@ U32 LLInventoryModel::updateItem(const LLViewerInventoryItem* item) { return mask; } + + if(!isInventoryUsable()) + { + llwarns << "Inventory is broken." << llendl; + return mask; + } + LLViewerInventoryItem* old_item = getItem(item->getUUID()); if(old_item) { @@ -588,6 +611,13 @@ void LLInventoryModel::updateCategory(const LLViewerInventoryCategory* cat) { return; } + + if(!isInventoryUsable()) + { + llwarns << "Inventory is broken." << llendl; + return; + } + LLViewerInventoryCategory* old_cat = getCategory(cat->getUUID()); if(old_cat) { @@ -645,6 +675,12 @@ void LLInventoryModel::updateCategory(const LLViewerInventoryCategory* cat) void LLInventoryModel::moveObject(const LLUUID& object_id, const LLUUID& cat_id) { lldebugs << "LLInventoryModel::moveObject()" << llendl; + if(!isInventoryUsable()) + { + llwarns << "Inventory is broken." << llendl; + return; + } + if((object_id == cat_id) || !is_in_map(mCategoryMap, cat_id)) { llwarns << "Could not move inventory object " << object_id << " to " @@ -1086,7 +1122,7 @@ void LLInventoryModel::backgroundFetch(void*) { // finished with this category, remove from queue sFetchQueue.pop_front(); - + // add all children to queue parent_cat_map_t::iterator cat_it = gInventory.mParentChildCategoryTree.find(cat->getUUID()); if (cat_it != gInventory.mParentChildCategoryTree.end()) @@ -1863,6 +1899,19 @@ void LLInventoryModel::buildParentChildMap() gAgent.sendReliableMessage(); } } + + const LLUUID& agent_inv_root_id = gAgent.getInventoryRootID(); + if (agent_inv_root_id.notNull()) + { + cat_array_t* catsp = get_ptr_in_map(mParentChildCategoryTree, agent_inv_root_id); + if(catsp) + { + // 'My Inventory', + // root of the agent's inv found. + // The inv tree is built. + mIsAgentInvUsable = true; + } + } } struct LLUUIDAndName @@ -2695,7 +2744,6 @@ void LLInventoryModel::dumpInventory() llinfos << "\n**********************\nEnd Inventory Dump" << llendl; } - ///---------------------------------------------------------------------------- /// LLInventoryCollectFunctor implementations ///---------------------------------------------------------------------------- diff --git a/linden/indra/newview/llinventorymodel.h b/linden/indra/newview/llinventorymodel.h index 78ab0e3..e321f1f 100644 --- a/linden/indra/newview/llinventorymodel.h +++ b/linden/indra/newview/llinventorymodel.h @@ -2,6 +2,8 @@ * @file llinventorymodel.h * @brief LLInventoryModel class header file * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLINVENTORYMODEL_H @@ -162,6 +165,11 @@ public: BOOL include_trash, LLInventoryCollectFunctor& add); + // This method will return false if this inventory model is in an usabel state. + // The inventory model usage is sensitive to the initial construction of the + // model. + bool isInventoryUsable(); + // // Mutators // @@ -428,6 +436,9 @@ protected: static F32 sMinTimeBetweenFetches; static F32 sMaxTimeBetweenFetches; + // This flag is used to handle an invalid inventory state. + bool mIsAgentInvUsable; + public: // *NOTE: DEBUG functionality void dumpInventory(); @@ -797,3 +808,4 @@ protected: #endif // LL_LLINVENTORYMODEL_H + diff --git a/linden/indra/newview/llinventoryview.cpp b/linden/indra/newview/llinventoryview.cpp index 8b7809d..2ac46ab 100644 --- a/linden/indra/newview/llinventoryview.cpp +++ b/linden/indra/newview/llinventoryview.cpp @@ -2,6 +2,8 @@ * @file llinventoryview.cpp * @brief Implementation of the inventory view and associated stuff. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -121,17 +124,40 @@ LLInventoryViewFinder::LLInventoryViewFinder(const LLString& name, mSpinSinceDays = LLUICtrlFactory::getSpinnerByName(this, "spin_days_ago"); childSetCommitCallback("spin_days_ago", onTimeAgo, this); +// mCheckSinceLogoff = LLUICtrlFactory::getSpinnerByName(this, "check_since_logoff"); + childSetCommitCallback("check_since_logoff", onCheckSinceLogoff, this); + childSetAction("Close", onCloseBtn, this); updateElementsFromFilter(); } -void LLInventoryViewFinder::onTimeAgo(LLUICtrl *ctrl, void *user_data) + +void LLInventoryViewFinder::onCheckSinceLogoff(LLUICtrl *ctrl, void *user_data) { LLInventoryViewFinder *self = (LLInventoryViewFinder *)user_data; if (!self) return; - self->childSetValue("check_since_logoff", FALSE); + bool since_logoff= self->childGetValue("check_since_logoff"); + + if (!since_logoff && + !( self->mSpinSinceDays->get() || self->mSpinSinceHours->get() ) ) + { + self->mSpinSinceHours->set(1.0f); + } +} + +void LLInventoryViewFinder::onTimeAgo(LLUICtrl *ctrl, void *user_data) +{ + LLInventoryViewFinder *self = (LLInventoryViewFinder *)user_data; + if (!self) return; + + bool since_logoff=true; + if ( self->mSpinSinceDays->get() || self->mSpinSinceHours->get() ) + { + since_logoff = false; + } + self->childSetValue("check_since_logoff", since_logoff); } void LLInventoryViewFinder::changeFilter(LLInventoryFilter* filter) diff --git a/linden/indra/newview/llinventoryview.h b/linden/indra/newview/llinventoryview.h index cba1d16..d2caa84 100644 --- a/linden/indra/newview/llinventoryview.h +++ b/linden/indra/newview/llinventoryview.h @@ -3,6 +3,8 @@ * @brief LLInventoryView, LLInventoryFolder, and LLInventoryItem * class definition * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLINVENTORYVIEW_H @@ -170,6 +173,7 @@ public: BOOL getCheckSinceLogoff(); static void onTimeAgo(LLUICtrl*, void *); + static void onCheckSinceLogoff(LLUICtrl*, void *); static void onCloseBtn(void* user_data); static void selectAllTypes(void* user_data); static void selectNoTypes(void* user_data); @@ -365,11 +369,6 @@ const BOOL TAKE_FOCUS_NO = FALSE; void rez_attachment(LLViewerInventoryItem* item, LLViewerJointAttachment* attachment); -extern const char* FIND_HINT; -extern const char* NAME_SEARCH_DESC; -extern const char* NEW_LSL_NAME; -extern const char* NEW_NOTECARD_NAME; -extern const char* NEW_GESTURE_NAME; - #endif // LL_LLINVENTORYVIEW_H + diff --git a/linden/indra/newview/lljoystickbutton.cpp b/linden/indra/newview/lljoystickbutton.cpp index 6e62627..20c4a25 100644 --- a/linden/indra/newview/lljoystickbutton.cpp +++ b/linden/indra/newview/lljoystickbutton.cpp @@ -2,6 +2,8 @@ * @file lljoystickbutton.cpp * @brief LLJoystick class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lljoystickbutton.h b/linden/indra/newview/lljoystickbutton.h index e947559..1524b4f 100644 --- a/linden/indra/newview/lljoystickbutton.h +++ b/linden/indra/newview/lljoystickbutton.h @@ -2,6 +2,8 @@ * @file lljoystickbutton.h * @brief LLJoystick class definition * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLJOYSTICKBUTTON_H diff --git a/linden/indra/newview/lllandmarklist.cpp b/linden/indra/newview/lllandmarklist.cpp index 7633be4..1d23dff 100644 --- a/linden/indra/newview/lllandmarklist.cpp +++ b/linden/indra/newview/lllandmarklist.cpp @@ -2,6 +2,8 @@ * @file lllandmarklist.cpp * @brief Landmark asset list class * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lllandmarklist.h b/linden/indra/newview/lllandmarklist.h index 1d69158..1777b64 100644 --- a/linden/indra/newview/lllandmarklist.h +++ b/linden/indra/newview/lllandmarklist.h @@ -2,6 +2,8 @@ * @file lllandmarklist.h * @brief Landmark asset list class * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLLANDMARKLIST_H diff --git a/linden/indra/newview/lllightconstants.h b/linden/indra/newview/lllightconstants.h index 5926229..f2fe594 100644 --- a/linden/indra/newview/lllightconstants.h +++ b/linden/indra/newview/lllightconstants.h @@ -2,6 +2,8 @@ * @file lllightconstants.h * @brief Constants for light functions * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLLIGHTCONSTANTS_H diff --git a/linden/indra/newview/lllocalanimationobject.cpp b/linden/indra/newview/lllocalanimationobject.cpp index c77b1ed..7730892 100644 --- a/linden/indra/newview/lllocalanimationobject.cpp +++ b/linden/indra/newview/lllocalanimationobject.cpp @@ -2,6 +2,8 @@ * @file lllocalanimationobject.cpp * @brief LLHUDLocalAnimationObject class implementation * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lllocalanimationobject.h b/linden/indra/newview/lllocalanimationobject.h index b834400..e7bb34b 100644 --- a/linden/indra/newview/lllocalanimationobject.h +++ b/linden/indra/newview/lllocalanimationobject.h @@ -2,6 +2,8 @@ * @file lllocalanimationobject.h * @brief LLHUDLocalAnimationObject class definition * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LOCALANIMATIONOBJECT_H diff --git a/linden/indra/newview/lllogchat.cpp b/linden/indra/newview/lllogchat.cpp index ec9b9f5..8620446 100644 --- a/linden/indra/newview/lllogchat.cpp +++ b/linden/indra/newview/lllogchat.cpp @@ -2,6 +2,8 @@ * @file lllogchat.cpp * @brief LLLogChat class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lllogchat.h b/linden/indra/newview/lllogchat.h index c82f04e..d5fd779 100644 --- a/linden/indra/newview/lllogchat.h +++ b/linden/indra/newview/lllogchat.h @@ -2,6 +2,8 @@ * @file lllogchat.h * @brief LLFloaterChat class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ diff --git a/linden/indra/newview/llmanip.cpp b/linden/indra/newview/llmanip.cpp index 3d27256..953befc 100644 --- a/linden/indra/newview/llmanip.cpp +++ b/linden/indra/newview/llmanip.cpp @@ -2,6 +2,8 @@ * @file llmanip.cpp * @brief LLManip class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -91,9 +94,10 @@ void LLManip::rebuild(LLViewerObject* vobj) LLManip::LLManip( const LLString& name, LLToolComposite* composite ) : LLTool( name, composite ), - mInSnapRegime(FALSE) -{} - + mInSnapRegime(FALSE), + mHighlightedPart(LL_NO_PART) +{ +} void LLManip::getManipNormal(LLViewerObject* object, EManipPart manip, LLVector3 &normal) { @@ -357,14 +361,11 @@ void LLManip::renderGuidelines(BOOL draw_x, BOOL draw_y, BOOL draw_z) LLVector3 grid_scale; gSelectMgr->getGrid(grid_origin, grid_rot, grid_scale); - LLViewerObject* object = mObjectSelection->getFirstRootObject(); + const BOOL children_ok = TRUE; + LLViewerObject* object = mObjectSelection->getFirstRootObject(children_ok); if (!object) { - object = mObjectSelection->getFirstObject(); - if (!object) - { - return; - } + return; } //LLVector3 center_agent = gSelectMgr->getBBoxOfSelection().getCenterAgent(); diff --git a/linden/indra/newview/llmanip.h b/linden/indra/newview/llmanip.h index 2b1e836..8c51746 100644 --- a/linden/indra/newview/llmanip.h +++ b/linden/indra/newview/llmanip.h @@ -2,6 +2,8 @@ * @file llmanip.h * @brief LLManip class definition * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_MANIP_H @@ -125,11 +128,13 @@ public: /*virtual*/ BOOL handleMouseUp(S32 x, S32 y, MASK mask); /*virtual*/ BOOL handleHover(S32 x, S32 y, MASK mask); - virtual EManipPart getHighlightedPart() { return LL_NO_PART; } - virtual void highlightManipulators(S32 x, S32 y) {}; + virtual void highlightManipulators(S32 x, S32 y) = 0; virtual void handleSelect(); virtual void handleDeselect(); + virtual BOOL canAffectSelection() = 0; + EManipPart getHighlightedPart() { return mHighlightedPart; } + LLHandle getSelection(); protected: @@ -149,6 +154,7 @@ protected: LLFrameTimer mHelpTextTimer; BOOL mInSnapRegime; LLHandle mObjectSelection; + EManipPart mHighlightedPart; static F32 sHelpTextVisibleTime; static F32 sHelpTextFadeTime; diff --git a/linden/indra/newview/llmaniprotate.cpp b/linden/indra/newview/llmaniprotate.cpp index 940e78a..fb3de3a 100644 --- a/linden/indra/newview/llmaniprotate.cpp +++ b/linden/indra/newview/llmaniprotate.cpp @@ -2,6 +2,8 @@ * @file llmaniprotate.cpp * @brief LLManipRotate class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -107,7 +110,7 @@ void LLManipRotate::handleSelect() { // *FIX: put this in mouseDown? gSelectMgr->saveSelectedObjectTransform(SELECT_ACTION_TYPE_PICK); - gFloaterTools->setStatusText("Drag colored bands to rotate object"); + gFloaterTools->setStatusText("rotate"); LLManip::handleSelect(); } @@ -115,8 +118,6 @@ void LLManipRotate::handleDeselect() { mHighlightedPart = LL_NO_PART; mManipPart = LL_NO_PART; - - gFloaterTools->setStatusText(""); LLManip::handleDeselect(); } @@ -376,14 +377,7 @@ BOOL LLManipRotate::handleMouseDown(S32 x, S32 y, MASK mask) // Assumes that one of the parts of the manipulator was hit. BOOL LLManipRotate::handleMouseDownOnPart( S32 x, S32 y, MASK mask ) { - BOOL can_rotate = mObjectSelection->getObjectCount() != 0; - for (LLViewerObject* objectp = mObjectSelection->getFirstObject(); - objectp; - objectp = mObjectSelection->getNextObject()) - { - can_rotate = can_rotate && objectp->permMove() && (objectp->permModify() || !gSavedSettings.getBOOL("EditLinkedParts")); - } - + BOOL can_rotate = canAffectSelection(); if (!can_rotate) { return FALSE; @@ -462,15 +456,18 @@ BOOL LLManipRotate::handleMouseUp(S32 x, S32 y, MASK mask) // first, perform normal processing in case this was a quick-click handleHover(x, y, mask); - mManipPart = LL_NO_PART; + if( hasMouseCapture() ) + { + mManipPart = LL_NO_PART; - // Might have missed last update due to timing. - gSelectMgr->sendMultipleUpdate( UPD_ROTATION | UPD_POSITION ); - gSelectMgr->enableSilhouette(TRUE); - //gAgent.setObjectTracking(gSavedSettings.getBOOL("TrackFocusObject")); + // Might have missed last update due to timing. + gSelectMgr->sendMultipleUpdate( UPD_ROTATION | UPD_POSITION ); + gSelectMgr->enableSilhouette(TRUE); + //gAgent.setObjectTracking(gSavedSettings.getBOOL("TrackFocusObject")); - gSelectMgr->updateSelectionCenter(); - gSelectMgr->saveSelectedObjectTransform(SELECT_ACTION_TYPE_PICK); + gSelectMgr->updateSelectionCenter(); + gSelectMgr->saveSelectedObjectTransform(SELECT_ACTION_TYPE_PICK); + } return LLManip::handleMouseUp(x, y, mask); } @@ -538,12 +535,11 @@ void LLManipRotate::drag( S32 x, S32 y ) BOOL damped = mSmoothRotate; mSmoothRotate = FALSE; - LLViewerObject* object; - LLSelectNode* selectNode; - - for( selectNode = mObjectSelection->getFirstNode(); selectNode != NULL; selectNode = mObjectSelection->getNextNode() ) + for (LLObjectSelection::iterator iter = mObjectSelection->begin(); + iter != mObjectSelection->end(); iter++) { - object = selectNode->getObject(); + LLSelectNode* selectNode = *iter; + LLViewerObject* object = selectNode->getObject(); // have permission to move and object is root of selection or individually selected if (object->permMove() && (object->isRootEdit() || selectNode->mIndividualSelection)) @@ -607,10 +603,12 @@ void LLManipRotate::drag( S32 x, S32 y ) } // update positions - for( selectNode = mObjectSelection->getFirstNode(); selectNode != NULL; selectNode = mObjectSelection->getNextNode() ) + for (LLObjectSelection::iterator iter = mObjectSelection->begin(); + iter != mObjectSelection->end(); iter++) { - object = selectNode->getObject(); - + LLSelectNode* selectNode = *iter; + LLViewerObject* object = selectNode->getObject(); + // to avoid cumulative position changes we calculate the objects new position using its saved position if (object && object->permMove()) { @@ -708,10 +706,10 @@ void LLManipRotate::drag( S32 x, S32 y ) } // store changes to override updates - for (LLSelectNode* selectNode = gSelectMgr->getSelection()->getFirstNode(); - selectNode != NULL; - selectNode = gSelectMgr->getSelection()->getNextNode()) + for (LLObjectSelection::iterator iter = gSelectMgr->getSelection()->begin(); + iter != gSelectMgr->getSelection()->end(); iter++) { + LLSelectNode* selectNode = *iter; LLViewerObject*cur = selectNode->getObject(); if( cur->permModify() && cur->permMove() && !cur->isAvatar()) { @@ -1866,3 +1864,22 @@ S32 LLManipRotate::getObjectAxisClosestToMouse(LLVector3& object_axis) return axis_index; } + +//virtual +BOOL LLManipRotate::canAffectSelection() +{ + BOOL can_rotate = mObjectSelection->getObjectCount() != 0; + if (can_rotate) + { + struct f : public LLSelectedObjectFunctor + { + virtual bool apply(LLViewerObject* objectp) + { + return objectp->permMove() && (objectp->permModify() || !gSavedSettings.getBOOL("EditLinkedParts")); + } + } func; + can_rotate = mObjectSelection->applyToObjects(&func); + } + return can_rotate; +} + diff --git a/linden/indra/newview/llmaniprotate.h b/linden/indra/newview/llmaniprotate.h index 80ff488..460bd3f 100644 --- a/linden/indra/newview/llmaniprotate.h +++ b/linden/indra/newview/llmaniprotate.h @@ -2,6 +2,8 @@ * @file llmaniprotate.h * @brief LLManipRotate class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMANIPROTATE_H @@ -63,9 +66,10 @@ public: virtual void handleSelect(); virtual void handleDeselect(); - BOOL handleMouseDownOnPart(S32 x, S32 y, MASK mask); + virtual BOOL handleMouseDownOnPart(S32 x, S32 y, MASK mask); virtual void highlightManipulators(S32 x, S32 y); - EManipPart getHighlightedPart() { return mHighlightedPart; } + virtual BOOL canAffectSelection(); + private: void updateHoverView(); @@ -108,7 +112,6 @@ private: EManipPart mManipPart; BOOL mSendUpdateOnMouseUp; - EManipPart mHighlightedPart; BOOL mSmoothRotate; BOOL mCamEdgeOn; diff --git a/linden/indra/newview/llmanipscale.cpp b/linden/indra/newview/llmanipscale.cpp index c130824..a67e3fc 100644 --- a/linden/indra/newview/llmanipscale.cpp +++ b/linden/indra/newview/llmanipscale.cpp @@ -2,6 +2,8 @@ * @file llmanipscale.cpp * @brief LLManipScale class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -159,7 +162,7 @@ void LLManipScale::handleSelect() LLBBox bbox = gSelectMgr->getBBoxOfSelection(); updateSnapGuides(bbox); gSelectMgr->saveSelectedObjectTransform(SELECT_ACTION_TYPE_PICK); - gFloaterTools->setStatusText("Click and drag to stretch selected side"); + gFloaterTools->setStatusText("scale"); LLManip::handleSelect(); } @@ -167,7 +170,6 @@ void LLManipScale::handleDeselect() { mHighlightedPart = LL_NO_PART; mManipPart = LL_NO_PART; - gFloaterTools->setStatusText(""); LLManip::handleDeselect(); } @@ -182,7 +184,6 @@ LLManipScale::LLManipScale( LLToolComposite* composite ) mBoxHandleSize( 1.f ), mScaledBoxHandleSize( 1.f ), mManipPart( LL_NO_PART ), - mHighlightedPart( LL_NO_PART ), mLastMouseX( -1 ), mLastMouseY( -1 ), mSendUpdateOnMouseUp( FALSE ), @@ -214,7 +215,7 @@ void LLManipScale::render() LLGLEnable gl_blend(GL_BLEND); LLGLEnable gls_alpha_test(GL_ALPHA_TEST); - if( isSelectionScalable() ) + if( canAffectSelection() ) { glMatrixMode(GL_MODELVIEW); glPushMatrix(); @@ -333,14 +334,7 @@ BOOL LLManipScale::handleMouseDown(S32 x, S32 y, MASK mask) // Assumes that one of the arrows on an object was hit. BOOL LLManipScale::handleMouseDownOnPart( S32 x, S32 y, MASK mask ) { - BOOL can_scale = mObjectSelection->getObjectCount() != 0; - for (LLViewerObject* objectp = mObjectSelection->getFirstObject(); - objectp; - objectp = mObjectSelection->getNextObject()) - { - can_scale = can_scale && objectp->permModify() && objectp->permMove() && !objectp->isSeat(); - } - + BOOL can_scale = canAffectSelection(); if (!can_scale) { return FALSE; @@ -380,29 +374,32 @@ BOOL LLManipScale::handleMouseUp(S32 x, S32 y, MASK mask) // first, perform normal processing in case this was a quick-click handleHover(x, y, mask); - if( (LL_FACE_MIN <= (S32)mManipPart) - && ((S32)mManipPart <= LL_FACE_MAX) ) - { - sendUpdates(TRUE,TRUE,FALSE); - } - else - if( (LL_CORNER_MIN <= (S32)mManipPart) - && ((S32)mManipPart <= LL_CORNER_MAX) ) + if( hasMouseCapture() ) { - sendUpdates(TRUE,TRUE,TRUE); - } - - //send texture update - gSelectMgr->adjustTexturesByScale(TRUE, getStretchTextures()); - - gSelectMgr->enableSilhouette(TRUE); - mManipPart = LL_NO_PART; + if( (LL_FACE_MIN <= (S32)mManipPart) + && ((S32)mManipPart <= LL_FACE_MAX) ) + { + sendUpdates(TRUE,TRUE,FALSE); + } + else + if( (LL_CORNER_MIN <= (S32)mManipPart) + && ((S32)mManipPart <= LL_CORNER_MAX) ) + { + sendUpdates(TRUE,TRUE,TRUE); + } + + //send texture update + gSelectMgr->adjustTexturesByScale(TRUE, getStretchTextures()); + + gSelectMgr->enableSilhouette(TRUE); + mManipPart = LL_NO_PART; - // Might have missed last update due to UPDATE_DELAY timing - gSelectMgr->sendMultipleUpdate( mLastUpdateFlags ); - - //gAgent.setObjectTracking(gSavedSettings.getBOOL("TrackFocusObject")); - gSelectMgr->saveSelectedObjectTransform(SELECT_ACTION_TYPE_PICK); + // Might have missed last update due to UPDATE_DELAY timing + gSelectMgr->sendMultipleUpdate( mLastUpdateFlags ); + + //gAgent.setObjectTracking(gSavedSettings.getBOOL("TrackFocusObject")); + gSelectMgr->saveSelectedObjectTransform(SELECT_ACTION_TYPE_PICK); + } return LLManip::handleMouseUp(x, y, mask); } @@ -444,7 +441,7 @@ void LLManipScale::highlightManipulators(S32 x, S32 y) // Don't do this with nothing selected, as it kills the framerate. LLBBox bbox = gSelectMgr->getBBoxOfSelection(); - if( isSelectionScalable() ) + if( canAffectSelection() ) { LLMatrix4 transform; if (mObjectSelection->getSelectType() == SELECT_TYPE_HUD) @@ -824,10 +821,10 @@ void LLManipScale::drag( S32 x, S32 y ) } // store changes to override updates - for (LLSelectNode* selectNode = gSelectMgr->getSelection()->getFirstNode(); - selectNode != NULL; - selectNode = gSelectMgr->getSelection()->getNextNode()) + for (LLObjectSelection::iterator iter = gSelectMgr->getSelection()->begin(); + iter != gSelectMgr->getSelection()->end(); iter++) { + LLSelectNode* selectNode = *iter; LLViewerObject*cur = selectNode->getObject(); if( cur->permModify() && cur->permMove() && !cur->isAvatar()) { @@ -971,9 +968,10 @@ void LLManipScale::dragCorner( S32 x, S32 y ) F32 min_scale_factor = MIN_OBJECT_SCALE / MAX_OBJECT_SCALE; // find max and min scale factors that will make biggest object hit max absolute scale and smallest object hit min absolute scale - LLSelectNode* selectNode; - for( selectNode = mObjectSelection->getFirstNode(); selectNode; selectNode = mObjectSelection->getNextNode() ) + for (LLObjectSelection::iterator iter = mObjectSelection->begin(); + iter != mObjectSelection->end(); iter++) { + LLSelectNode* selectNode = *iter; LLViewerObject* cur = selectNode->getObject(); if( cur->permModify() && cur->permMove() && !cur->isAvatar() ) { @@ -992,8 +990,10 @@ void LLManipScale::dragCorner( S32 x, S32 y ) LLVector3d drag_global = uniform ? mDragStartCenterGlobal : mDragFarHitGlobal; // do the root objects i.e. (TRUE == cur->isRootEdit()) - for( selectNode = mObjectSelection->getFirstNode(); selectNode; selectNode = mObjectSelection->getNextNode() ) + for (LLObjectSelection::iterator iter = mObjectSelection->begin(); + iter != mObjectSelection->end(); iter++) { + LLSelectNode* selectNode = *iter; LLViewerObject* cur = selectNode->getObject(); if( cur->permModify() && cur->permMove() && !cur->isAvatar() && cur->isRootEdit() ) { @@ -1036,8 +1036,10 @@ void LLManipScale::dragCorner( S32 x, S32 y ) } } // do the child objects i.e. (FALSE == cur->isRootEdit()) - for( selectNode = mObjectSelection->getFirstNode(); selectNode; selectNode = mObjectSelection->getNextNode() ) + for (LLObjectSelection::iterator iter = mObjectSelection->begin(); + iter != mObjectSelection->end(); iter++) { + LLSelectNode* selectNode = *iter; LLViewerObject*cur = selectNode->getObject(); if( cur->permModify() && cur->permMove() && !cur->isAvatar() && !cur->isRootEdit() ) { @@ -1242,9 +1244,10 @@ void LLManipScale::stretchFace( const LLVector3& drag_start_agent, const LLVecto { LLVector3 drag_start_center_agent = gAgent.getPosAgentFromGlobal(mDragStartCenterGlobal); - LLSelectNode *selectNode; - for( selectNode = mObjectSelection->getFirstNode(); selectNode; selectNode = mObjectSelection->getNextNode() ) + for (LLObjectSelection::iterator iter = mObjectSelection->begin(); + iter != mObjectSelection->end(); iter++) { + LLSelectNode* selectNode = *iter; LLViewerObject*cur = selectNode->getObject(); if( cur->permModify() && cur->permMove() && !cur->isAvatar() ) { @@ -2037,23 +2040,22 @@ LLVector3 LLManipScale::nearestAxis( const LLVector3& v ) const return LLVector3( coords[greatest_index] ); } -//FIXME: make this const once we switch to iterator interface -//(making object traversal a const-able operation) -BOOL LLManipScale::isSelectionScalable() +// virtual +BOOL LLManipScale::canAffectSelection() { // An selection is scalable if you are allowed to both edit and move // everything in it, and it does not have any sitting agents - BOOL scalable = mObjectSelection->getFirstObject() ? TRUE : FALSE; - for(LLViewerObject* cur = mObjectSelection->getFirstObject(); - cur; - cur = mObjectSelection->getNextObject() ) + BOOL can_scale = mObjectSelection->getObjectCount() != 0; + if (can_scale) { - if( !(cur->permModify() && cur->permMove()) - || cur->isSeat()) + struct f : public LLSelectedObjectFunctor { - scalable = FALSE; - break; - } - } - return scalable; + virtual bool apply(LLViewerObject* objectp) + { + return objectp->permModify() && objectp->permMove() && !objectp->isSeat(); + } + } func; + can_scale = mObjectSelection->applyToObjects(&func); + } + return can_scale; } diff --git a/linden/indra/newview/llmanipscale.h b/linden/indra/newview/llmanipscale.h index 40c8a53..3ea5ee7 100644 --- a/linden/indra/newview/llmanipscale.h +++ b/linden/indra/newview/llmanipscale.h @@ -2,6 +2,8 @@ * @file llmanipscale.h * @brief LLManipScale class definition * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_MANIPSCALE_H @@ -75,9 +78,9 @@ public: virtual void handleSelect(); virtual void handleDeselect(); - BOOL handleMouseDownOnPart(S32 x, S32 y, MASK mask); - EManipPart getHighlightedPart() { return mHighlightedPart; } + virtual BOOL handleMouseDownOnPart(S32 x, S32 y, MASK mask); virtual void highlightManipulators(S32 x, S32 y); // decided which manipulator, if any, should be highlighted by mouse hover + virtual BOOL canAffectSelection(); static void setUniform( BOOL b ); static BOOL getUniform(); @@ -114,8 +117,6 @@ private: F32 partToMinScale( S32 part, const LLBBox& bbox ) const; LLVector3 nearestAxis( const LLVector3& v ) const; - BOOL isSelectionScalable(); - void stretchFace( const LLVector3& drag_start_agent, const LLVector3& drag_delta_agent); void adjustTextureRepeats(); // Adjusts texture coords based on mSavedScale and current scale, only works for boxes @@ -130,7 +131,6 @@ private: LLVector3d mDragStartCenterGlobal; // The center of the bounding box of all selected objects at time of drag start LLVector3d mDragPointGlobal; LLVector3d mDragFarHitGlobal; - EManipPart mHighlightedPart; S32 mLastMouseX; S32 mLastMouseY; BOOL mSendUpdateOnMouseUp; diff --git a/linden/indra/newview/llmaniptranslate.cpp b/linden/indra/newview/llmaniptranslate.cpp index e405dc4..1963b1a 100644 --- a/linden/indra/newview/llmaniptranslate.cpp +++ b/linden/indra/newview/llmaniptranslate.cpp @@ -2,6 +2,8 @@ * @file llmaniptranslate.cpp * @brief LLManipTranslate class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /** @@ -258,7 +261,7 @@ LLManipTranslate::~LLManipTranslate() void LLManipTranslate::handleSelect() { gSelectMgr->saveSelectedObjectTransform(SELECT_ACTION_TYPE_PICK); - gFloaterTools->setStatusText("Drag to move, shift-drag to copy"); + gFloaterTools->setStatusText("move"); LLManip::handleSelect(); } @@ -266,7 +269,6 @@ void LLManipTranslate::handleDeselect() { mHighlightedPart = LL_NO_PART; mManipPart = LL_NO_PART; - gFloaterTools->setStatusText(""); LLManip::handleDeselect(); } @@ -293,14 +295,7 @@ BOOL LLManipTranslate::handleMouseDown(S32 x, S32 y, MASK mask) // Assumes that one of the arrows on an object was hit. BOOL LLManipTranslate::handleMouseDownOnPart( S32 x, S32 y, MASK mask ) { - BOOL can_move = mObjectSelection->getObjectCount() != 0; - for (LLViewerObject* objectp = mObjectSelection->getFirstObject(); - objectp; - objectp = mObjectSelection->getNextObject()) - { - can_move = can_move && objectp->permMove() && (objectp->permModify() || !gSavedSettings.getBOOL("EditLinkedParts")); - } - + BOOL can_move = canAffectSelection(); if (!can_move) { return FALSE; @@ -428,8 +423,6 @@ BOOL LLManipTranslate::handleHover(S32 x, S32 y, MASK mask) } } - LLViewerObject *object; - // Suppress processing if mouse hasn't actually moved. // This may cause problems if the camera moves outside of the // rotation above. @@ -488,7 +481,7 @@ BOOL LLManipTranslate::handleHover(S32 x, S32 y, MASK mask) return TRUE; } - object = selectNode->getObject(); + LLViewerObject* object = selectNode->getObject(); if (!object) { // somehow we lost the object! @@ -651,11 +644,11 @@ BOOL LLManipTranslate::handleHover(S32 x, S32 y, MASK mask) LLVector3d clamped_relative_move = axis_magnitude * axis_d; // scalar multiply LLVector3 clamped_relative_move_f = (F32)axis_magnitude * axis_f; // scalar multiply - for(selectNode = mObjectSelection->getFirstNode(); - selectNode; - selectNode = mObjectSelection->getNextNode() ) + for (LLObjectSelection::iterator iter = mObjectSelection->begin(); + iter != mObjectSelection->end(); iter++) { - object = selectNode->getObject(); + LLSelectNode* selectNode = *iter; + LLViewerObject* object = selectNode->getObject(); // Only apply motion to root objects and objects selected // as "individual". @@ -1044,16 +1037,19 @@ BOOL LLManipTranslate::handleMouseUp(S32 x, S32 y, MASK mask) // first, perform normal processing in case this was a quick-click handleHover(x, y, mask); - // make sure arrow colors go back to normal - mManipPart = LL_NO_PART; - gSelectMgr->enableSilhouette(TRUE); + if(hasMouseCapture()) + { + // make sure arrow colors go back to normal + mManipPart = LL_NO_PART; + gSelectMgr->enableSilhouette(TRUE); - // Might have missed last update due to UPDATE_DELAY timing. - gSelectMgr->sendMultipleUpdate( UPD_POSITION ); - - mInSnapRegime = FALSE; - gSelectMgr->saveSelectedObjectTransform(SELECT_ACTION_TYPE_PICK); - //gAgent.setObjectTracking(gSavedSettings.getBOOL("TrackFocusObject")); + // Might have missed last update due to UPDATE_DELAY timing. + gSelectMgr->sendMultipleUpdate( UPD_POSITION ); + + mInSnapRegime = FALSE; + gSelectMgr->saveSelectedObjectTransform(SELECT_ACTION_TYPE_PICK); + //gAgent.setObjectTracking(gSavedSettings.getBOOL("TrackFocusObject")); + } return LLManip::handleMouseUp(x, y, mask); } @@ -1736,12 +1732,8 @@ void LLManipTranslate::renderText() } else { - LLViewerObject* objectp = mObjectSelection->getFirstRootObject(); - if(!objectp) - { - objectp = mObjectSelection->getFirstObject(); - } - + const BOOL children_ok = TRUE; + LLViewerObject* objectp = mObjectSelection->getFirstRootObject(children_ok); if (objectp) { renderXYZ(objectp->getPositionEdit()); @@ -2261,3 +2253,21 @@ void LLManipTranslate::renderGridVert(F32 x_trans, F32 y_trans, F32 r, F32 g, F3 } } + +// virtual +BOOL LLManipTranslate::canAffectSelection() +{ + BOOL can_move = mObjectSelection->getObjectCount() != 0; + if (can_move) + { + struct f : public LLSelectedObjectFunctor + { + virtual bool apply(LLViewerObject* objectp) + { + return objectp->permMove() && (objectp->permModify() || !gSavedSettings.getBOOL("EditLinkedParts")); + } + } func; + can_move = mObjectSelection->applyToObjects(&func); + } + return can_move; +} diff --git a/linden/indra/newview/llmaniptranslate.h b/linden/indra/newview/llmaniptranslate.h index 04c3d5a..8821b64 100644 --- a/linden/indra/newview/llmaniptranslate.h +++ b/linden/indra/newview/llmaniptranslate.h @@ -2,6 +2,8 @@ * @file llmaniptranslate.h * @brief LLManipTranslate class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMANIPTRANSLATE_H @@ -61,9 +64,9 @@ public: virtual void handleSelect(); virtual void handleDeselect(); - EManipPart getHighlightedPart() { return mHighlightedPart; } virtual void highlightManipulators(S32 x, S32 y); - /*virtual*/ BOOL handleMouseDownOnPart(S32 x, S32 y, MASK mask); + virtual BOOL handleMouseDownOnPart(S32 x, S32 y, MASK mask); + virtual BOOL canAffectSelection(); protected: enum EHandleType { @@ -104,7 +107,6 @@ private: LLTimer mUpdateTimer; LLLinkedList mProjectedManipulators; LLVector4 mManipulatorVertices[18]; - EManipPart mHighlightedPart; F32 mSnapOffsetMeters; LLVector3 mSnapOffsetAxis; LLQuaternion mGridRotation; diff --git a/linden/indra/newview/llmapresponders.cpp b/linden/indra/newview/llmapresponders.cpp index 9d84064..30c88b7 100644 --- a/linden/indra/newview/llmapresponders.cpp +++ b/linden/indra/newview/llmapresponders.cpp @@ -2,6 +2,8 @@ * @file llmapresponders.cpp * @brief Processes responses received for map requests. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llmapresponders.h b/linden/indra/newview/llmapresponders.h index 57f54b7..710eadf 100644 --- a/linden/indra/newview/llmapresponders.h +++ b/linden/indra/newview/llmapresponders.h @@ -2,6 +2,8 @@ * @file llmapresponders.h * @brief Processes responses received for map requests. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMAPLAYERRESPONDER_H diff --git a/linden/indra/newview/llmediaremotectrl.cpp b/linden/indra/newview/llmediaremotectrl.cpp index 0d524b0..9dcc9bc 100644 --- a/linden/indra/newview/llmediaremotectrl.cpp +++ b/linden/indra/newview/llmediaremotectrl.cpp @@ -2,6 +2,8 @@ * @file llmediaremotectrl.cpp * @brief A remote control for media (video and music) * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -60,7 +63,7 @@ BOOL LLMediaRemoteCtrl::postBuild() childSetAction("music_stop",LLOverlayBar::musicStop,this); childSetAction("music_pause",LLOverlayBar::musicPause,this); - childSetAction("volume",LLOverlayBar::toggleAudioVolumeFloater,this); + childSetAction("volume",LLOverlayBar::toggleAudioVolumeFloater,this); return TRUE; } diff --git a/linden/indra/newview/llmediaremotectrl.h b/linden/indra/newview/llmediaremotectrl.h index 4f4ba77..98bc263 100644 --- a/linden/indra/newview/llmediaremotectrl.h +++ b/linden/indra/newview/llmediaremotectrl.h @@ -2,6 +2,8 @@ * @file llmediaremotectrl.h * @brief A remote control for media (video and music) * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMEDIAREMOTECTRL_H diff --git a/linden/indra/newview/llmemoryview.cpp b/linden/indra/newview/llmemoryview.cpp index c29b33f..53582ac 100644 --- a/linden/indra/newview/llmemoryview.cpp +++ b/linden/indra/newview/llmemoryview.cpp @@ -2,6 +2,8 @@ * @file llmemoryview.cpp * @brief LLMemoryView class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llmemoryview.h b/linden/indra/newview/llmemoryview.h index 809e40f..88889d1 100644 --- a/linden/indra/newview/llmemoryview.h +++ b/linden/indra/newview/llmemoryview.h @@ -2,6 +2,8 @@ * @file llmemoryview.h * @brief LLMemoryView class definition * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMEMORYVIEW_H diff --git a/linden/indra/newview/llmenucommands.cpp b/linden/indra/newview/llmenucommands.cpp index 43f783e..92c7832 100644 --- a/linden/indra/newview/llmenucommands.cpp +++ b/linden/indra/newview/llmenucommands.cpp @@ -2,6 +2,8 @@ * @file llmenucommands.cpp * @brief Implementations of menu commands. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llmenucommands.h b/linden/indra/newview/llmenucommands.h index 08cee43..72167f0 100644 --- a/linden/indra/newview/llmenucommands.h +++ b/linden/indra/newview/llmenucommands.h @@ -2,6 +2,8 @@ * @file llmenucommands.h * @brief Implementations of menu commands. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMENUCOMMANDS_H diff --git a/linden/indra/newview/llmorphview.cpp b/linden/indra/newview/llmorphview.cpp index 1a28fd7..d69968d 100644 --- a/linden/indra/newview/llmorphview.cpp +++ b/linden/indra/newview/llmorphview.cpp @@ -2,6 +2,8 @@ * @file llmorphview.cpp * @brief Container for Morph functionality * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llmorphview.h b/linden/indra/newview/llmorphview.h index 6abc630..ecabaa9 100644 --- a/linden/indra/newview/llmorphview.h +++ b/linden/indra/newview/llmorphview.h @@ -2,6 +2,8 @@ * @file llmorphview.h * @brief Container for character morph controls * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMORPHVIEW_H diff --git a/linden/indra/newview/llmoveview.cpp b/linden/indra/newview/llmoveview.cpp index 2f4c8d1..e115f10 100644 --- a/linden/indra/newview/llmoveview.cpp +++ b/linden/indra/newview/llmoveview.cpp @@ -2,6 +2,8 @@ * @file llmoveview.cpp * @brief Container for movement buttons like forward, left, fly * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llmoveview.h b/linden/indra/newview/llmoveview.h index d0179b2..e08f20a 100644 --- a/linden/indra/newview/llmoveview.h +++ b/linden/indra/newview/llmoveview.h @@ -2,6 +2,8 @@ * @file llmoveview.h * @brief Container for buttons for walking, turning, flying * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLMOVEVIEW_H diff --git a/linden/indra/newview/llmutelist.cpp b/linden/indra/newview/llmutelist.cpp index 024123e..118fd42 100644 --- a/linden/indra/newview/llmutelist.cpp +++ b/linden/indra/newview/llmutelist.cpp @@ -3,6 +3,8 @@ * @author Richard Nelson, James Cook * @brief Management of list of muted players * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /* @@ -274,14 +277,14 @@ BOOL LLMuteList::add(const LLMute& mute, U32 flags) if (result.second) { llinfos << "Muting " << localmute.mName << " id " << localmute.mID << " flags " << localmute.mFlags << llendl; - updateAdd(mute); + updateAdd(localmute); notifyObservers(); if(!(localmute.mFlags & LLMute::flagParticles)) { //Kill all particle systems owned by muted task if(localmute.mType == LLMute::AGENT || localmute.mType == LLMute::OBJECT) { - gWorldPointer->mPartSim.cleanMutedParticles(localmute.mID); + gWorldPointer->mPartSim.clearParticlesByOwnerID(localmute.mID); } } return TRUE; diff --git a/linden/indra/newview/llmutelist.h b/linden/indra/newview/llmutelist.h index 63bee60..23e0620 100644 --- a/linden/indra/newview/llmutelist.h +++ b/linden/indra/newview/llmutelist.h @@ -2,6 +2,8 @@ * @file llmutelist.h * @brief Management of list of muted players * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_MUTELIST_H @@ -57,7 +60,7 @@ public: flagAll = 0x0000000F // Mask of all currently defined flags }; - LLMute(const LLUUID& id, const LLString& name = "", EType type = BY_NAME, U32 flags = 0) + LLMute(const LLUUID& id, const LLString& name = LLString(), EType type = BY_NAME, U32 flags = 0) : mID(id), mName(name), mType(type),mFlags(flags) { } // Returns name + suffix based on type diff --git a/linden/indra/newview/llnamebox.cpp b/linden/indra/newview/llnamebox.cpp index a5eee6a..b5021ef 100644 --- a/linden/indra/newview/llnamebox.cpp +++ b/linden/indra/newview/llnamebox.cpp @@ -2,6 +2,8 @@ * @file llnamebox.cpp * @brief A text display widget * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -54,7 +57,7 @@ LLNameBox::LLNameBox(const std::string& name, const LLRect& rect, const LLUUID& } else { - setText(""); + setText(LLString::null); } } diff --git a/linden/indra/newview/llnamebox.h b/linden/indra/newview/llnamebox.h index 74fd0a2..5fd92f5 100644 --- a/linden/indra/newview/llnamebox.h +++ b/linden/indra/newview/llnamebox.h @@ -2,6 +2,8 @@ * @file llnamebox.h * @brief display and refresh a name from the name cache * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLNAMEBOX_H diff --git a/linden/indra/newview/llnameeditor.cpp b/linden/indra/newview/llnameeditor.cpp index 5362ba7..ba12805 100644 --- a/linden/indra/newview/llnameeditor.cpp +++ b/linden/indra/newview/llnameeditor.cpp @@ -2,6 +2,8 @@ * @file llnameeditor.cpp * @brief Name Editor to refresh a name. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llnameeditor.h b/linden/indra/newview/llnameeditor.h index 60e0432..526b76b 100644 --- a/linden/indra/newview/llnameeditor.h +++ b/linden/indra/newview/llnameeditor.h @@ -2,6 +2,8 @@ * @file llnameeditor.h * @brief display and refresh a name from the name cache * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLNAMEEDITOR_H diff --git a/linden/indra/newview/llnamelistctrl.cpp b/linden/indra/newview/llnamelistctrl.cpp index 98745b4..adcc141 100644 --- a/linden/indra/newview/llnamelistctrl.cpp +++ b/linden/indra/newview/llnamelistctrl.cpp @@ -2,6 +2,8 @@ * @file llnamelistctrl.cpp * @brief A list of names, automatically refreshed from name cache. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -154,7 +157,7 @@ void LLNameListCtrl::addGroupNameItem(LLScrollListItem* item, EAddPosition pos) gCacheName->getGroupName(item->getUUID(), group_name); LLScrollListCell* cell = (LLScrollListCell*)item->getColumn(mNameColumnIndex); - ((LLScrollListText*)cell)->setText( group_name ); + ((LLScrollListText*)cell)->setText( LLString(group_name) ); addItem(item, pos); } @@ -458,3 +461,4 @@ LLView* LLNameListCtrl::fromXML(LLXMLNodePtr node, LLView *parent, LLUICtrlFacto } + diff --git a/linden/indra/newview/llnamelistctrl.h b/linden/indra/newview/llnamelistctrl.h index cded3cf..e6efd4e 100644 --- a/linden/indra/newview/llnamelistctrl.h +++ b/linden/indra/newview/llnamelistctrl.h @@ -2,6 +2,8 @@ * @file llnamelistctrl.h * @brief A list of names, automatically refreshing from the name cache. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLNAMELISTCTRL_H diff --git a/linden/indra/newview/llnetmap.cpp b/linden/indra/newview/llnetmap.cpp index 4701aae..edf2567 100644 --- a/linden/indra/newview/llnetmap.cpp +++ b/linden/indra/newview/llnetmap.cpp @@ -3,6 +3,8 @@ * @author James Cook * @brief Display of surrounding regions, objects, and agents. View contained by LLFloaterMap. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -49,11 +52,13 @@ #include "llstatgraph.h" #include "llsurface.h" #include "lltextbox.h" +#include "lluuid.h" #include "llviewercamera.h" #include "llviewerimage.h" #include "llviewerimagelist.h" #include "llviewermenu.h" #include "llviewerobjectlist.h" +#include "llviewermenu.h" #include "llviewerparceloverlay.h" #include "llviewerregion.h" #include "llviewerwindow.h" @@ -401,6 +406,8 @@ void LLNetMap::draw() LLVector3 pos_local; U32 compact_local; U8 bits; + // TODO: it'd be very cool to draw these in sorted order from lowest Z to highest. + // just be careful to sort the avatar IDs along with the positions. -MG for (i = 0; i < count; i++) { compact_local = regionp->mMapAvatars.get(i); @@ -420,9 +427,16 @@ void LLNetMap::draw() pos_global += origin_global; pos_map = globalPosToView(pos_global); - LLWorldMapView::drawAvatar(pos_map.mV[VX], pos_map.mV[VY], - gAvatarMapColor, - pos_map.mV[VZ]); + + BOOL show_as_friend = FALSE; + if( i < regionp->mMapAvatarIDs.count()) + { + show_as_friend = is_agent_friend(regionp->mMapAvatarIDs.get(i)); + } + LLWorldMapView::drawAvatar( + pos_map.mV[VX], pos_map.mV[VY], + show_as_friend ? gFriendMapColor : gAvatarMapColor, + pos_map.mV[VZ]); } } diff --git a/linden/indra/newview/llnetmap.h b/linden/indra/newview/llnetmap.h index ac5e602..40d8064 100644 --- a/linden/indra/newview/llnetmap.h +++ b/linden/indra/newview/llnetmap.h @@ -2,6 +2,8 @@ * @file llnetmap.h * @brief A little map of the world with network information * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLNETMAP_H diff --git a/linden/indra/newview/llnotify.cpp b/linden/indra/newview/llnotify.cpp index 7c206bb..92224b8 100644 --- a/linden/indra/newview/llnotify.cpp +++ b/linden/indra/newview/llnotify.cpp @@ -2,6 +2,8 @@ * @file llnotify.cpp * @brief Non-blocking notification that doesn't take keyboard focus. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -584,11 +587,14 @@ void LLNotifyBox::moveToBack() if (gNotifyBoxView->getChildCount() > 0) { LLNotifyBox* front = gNotifyBoxView->getFirstNontipBox(); - gNotifyBoxView->showOnly(front); - // assuming that moveToBack is only called by clicking the next button, - // we give focus to the next next button - front->mNextBtn->setFocus(TRUE); - gFocusMgr.triggerFocusFlash(); // TODO: it's ugly to call this here + if (front) + { + gNotifyBoxView->showOnly(front); + // assuming that moveToBack is only called by clicking the next button, + // we give focus to the next next button + front->mNextBtn->setFocus(TRUE); + gFocusMgr.triggerFocusFlash(); // TODO: it's ugly to call this here + } } } } @@ -910,7 +916,7 @@ bool LLNotifyBox::parseNotify(const LLString& xml_filename) } } - //XUI:translate + //*TODO:translate if (xml_template->mOptions.empty()) { xml_template->addOption("OK", FALSE); @@ -927,12 +933,17 @@ LLNotifyBoxView::LLNotifyBoxView(const LLString& name, const LLRect& rect, BOOL LLNotifyBox * LLNotifyBoxView::getFirstNontipBox() const { + // *TODO: Don't make assumptions like this! // assumes every child is a notify box for(child_list_const_iter_t iter = getChildList()->begin(); iter != getChildList()->end(); iter++) { - LLNotifyBox * box = static_cast(*iter); + // hack! *TODO: Integrate llnotify and llgroupnotify + LLView* view = *iter; + if (view->getName() == "groupnotify") + continue; + LLNotifyBox* box = static_cast(view); if(!box->isTip() && !box->isDead()) { return box; diff --git a/linden/indra/newview/llnotify.h b/linden/indra/newview/llnotify.h index b08634d..3d7bf6d 100644 --- a/linden/indra/newview/llnotify.h +++ b/linden/indra/newview/llnotify.h @@ -2,6 +2,8 @@ * @file llnotify.h * @brief Non-blocking notification that doesn't take keyboard focus. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLNOTIFY_H @@ -165,7 +168,7 @@ public: LLNotifyBox * getFirstNontipBox() const; virtual EWidgetType getWidgetType() const { return WIDGET_TYPE_VIEW; }; - virtual LLString getWidgetTag() const { return ""; } + virtual LLString getWidgetTag() const { return LLString(); } }; // This view contains the stack of notification windows. diff --git a/linden/indra/newview/lloverlaybar.cpp b/linden/indra/newview/lloverlaybar.cpp index f5addd0..d8131c2 100644 --- a/linden/indra/newview/lloverlaybar.cpp +++ b/linden/indra/newview/lloverlaybar.cpp @@ -2,6 +2,8 @@ * @file lloverlaybar.cpp * @brief LLOverlayBar class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Temporary buttons that appear at the bottom of the screen when you @@ -357,8 +360,7 @@ void LLOverlayBar::refresh() { LLParcel* parcel = gParcelMgr->getAgentParcel(); if (!parcel - || !parcel->getMusicURL() - || !parcel->getMusicURL()[0] + || parcel->getMusicURL().empty() || !gSavedSettings.getBOOL("AudioStreamingMusic")) { mMusicRemote->setVisible(FALSE); @@ -506,7 +508,7 @@ void LLOverlayBar::musicPlay(void*) // stream is stopped, it doesn't return the right thing - commenting out for now. // if ( gAudiop->isInternetStreamPlaying() == 0 ) { - gAudiop->startInternetStream(parcel->getMusicURL()); + gAudiop->startInternetStream(parcel->getMusicURL().c_str()); } } } diff --git a/linden/indra/newview/lloverlaybar.h b/linden/indra/newview/lloverlaybar.h index de6c0ae..d8b9ba1 100644 --- a/linden/indra/newview/lloverlaybar.h +++ b/linden/indra/newview/lloverlaybar.h @@ -2,6 +2,8 @@ * @file lloverlaybar.h * @brief LLOverlayBar class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLOVERLAYBAR_H diff --git a/linden/indra/newview/llpanelaudioprefs.cpp b/linden/indra/newview/llpanelaudioprefs.cpp index b28fb83..a4591dc 100644 --- a/linden/indra/newview/llpanelaudioprefs.cpp +++ b/linden/indra/newview/llpanelaudioprefs.cpp @@ -2,6 +2,8 @@ * @file llpanelaudioprefs.cpp * @brief Audio preference implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llpanelaudioprefs.h b/linden/indra/newview/llpanelaudioprefs.h index 9fd4e8d..c573d0f 100644 --- a/linden/indra/newview/llpanelaudioprefs.h +++ b/linden/indra/newview/llpanelaudioprefs.h @@ -2,6 +2,8 @@ * @file llpanelaudioprefs.h * @brief Audio preference definitions * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELAUDIOPREFS_H diff --git a/linden/indra/newview/llpanelaudiovolume.cpp b/linden/indra/newview/llpanelaudiovolume.cpp index 902614e..56f03da 100644 --- a/linden/indra/newview/llpanelaudiovolume.cpp +++ b/linden/indra/newview/llpanelaudiovolume.cpp @@ -2,6 +2,8 @@ * @file llpanelaudiovolume.cpp * @brief A remote control for media (video and music) * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -72,14 +75,6 @@ LLPanelAudioVolume::LLPanelAudioVolume() BOOL LLPanelAudioVolume::postBuild() { - childSetAction("media_play",LLOverlayBar::mediaPlay,this); - childSetAction("media_stop",LLOverlayBar::mediaStop,this); - childSetAction("media_pause",LLOverlayBar::mediaPause,this); - - childSetAction("music_play",LLOverlayBar::musicPlay,this); - childSetAction("music_stop",LLOverlayBar::musicStop,this); - childSetAction("music_pause",LLOverlayBar::musicPause,this); - return TRUE; } @@ -92,8 +87,8 @@ LLPanelAudioVolume::~LLPanelAudioVolume () // void LLPanelAudioVolume::draw() { - LLOverlayBar::enableMusicButtons(this); - LLOverlayBar::enableMediaButtons(this); +// LLOverlayBar::enableMusicButtons(this); +// LLOverlayBar::enableMediaButtons(this); BOOL mute = gSavedSettings.getBOOL("MuteAudio"); bool enable = mute ? false : true; childSetEnabled("System Volume", enable); @@ -103,7 +98,7 @@ void LLPanelAudioVolume::draw() childSetEnabled("SFX Volume", enable); childSetEnabled("UI Volume", enable); childSetEnabled("Wind Volume", enable); - childSetEnabled("Footsteps Volume", enable); LLPanel::draw(); } + diff --git a/linden/indra/newview/llpanelaudiovolume.h b/linden/indra/newview/llpanelaudiovolume.h index 8a824d2..cb16a8f 100644 --- a/linden/indra/newview/llpanelaudiovolume.h +++ b/linden/indra/newview/llpanelaudiovolume.h @@ -2,6 +2,8 @@ * @file llpanelaudiovolume.h * @brief Audio preference definitions * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELAUDIOVOLUME_H diff --git a/linden/indra/newview/llpanelavatar.cpp b/linden/indra/newview/llpanelavatar.cpp index b79993f..dc2f14f 100644 --- a/linden/indra/newview/llpanelavatar.cpp +++ b/linden/indra/newview/llpanelavatar.cpp @@ -2,6 +2,8 @@ * @file llpanelavatar.cpp * @brief LLPanelAvatar and related class implementations * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -84,36 +87,6 @@ std::list LLPanelAvatar::sAllPanels; BOOL LLPanelAvatar::sAllowFirstLife = FALSE; -//----------------------------------------------------------------------------- -// Constants -//----------------------------------------------------------------------------- - -// RN: move these to lldbstrings.h -static const S32 DB_USER_FAVORITES_STR_LEN = 254; - -const char LOADING_MSG[] = "Loading..."; -static const char IM_DISABLED_TOOLTIP[] = "Instant Message (IM).\nDisabled because you do not have their card."; -static const char IM_ENABLED_TOOLTIP[] = "Instant Message (IM)"; -static const S32 LEFT = HPAD; - -static const S32 RULER0 = 65; -static const S32 RULER1 = RULER0 + 5; -static const S32 RULER2 = RULER1 + 90; -static const S32 RULER3 = RULER2 + 90; -static const S32 RULER4 = RULER3 + 10; - -static const S32 PICT_WIDTH = 180; -static const S32 PICT_HEIGHT = 135; - -static const S32 RULER5 = RULER4 + 140; -static const S32 WIDTH = RULER5 + 16; - -static const S32 MAX_CHARS = 254; - -static const LLColor4 WHITE(1,1,1,1); -static const LLColor4 BLACK(0,0,0,1); -static const LLColor4 CLEAR(0,0,0,0); - extern void handle_lure(const LLUUID& invitee); extern void handle_pay_by_id(const LLUUID& payee); @@ -314,8 +287,8 @@ void LLPanelAvatarSecondLife::updatePartnerName() BOOL found = gCacheName->getName(mPartnerID, first, last); if (found) { - childSetTextArg("partner_edit", "[FIRST]", first); - childSetTextArg("partner_edit", "[LAST]", last); + childSetTextArg("partner_edit", "[FIRST]", LLString(first)); + childSetTextArg("partner_edit", "[LAST]", LLString(last)); } } } @@ -336,8 +309,8 @@ void LLPanelAvatarSecondLife::clearControls() childSetValue("born", ""); childSetValue("acct", ""); - childSetTextArg("partner_edit", "[FIRST]", ""); - childSetTextArg("partner_edit", "[LAST]", ""); + childSetTextArg("partner_edit", "[FIRST]", LLString::null); + childSetTextArg("partner_edit", "[LAST]", LLString::null); mPartnerID = LLUUID::null; @@ -373,7 +346,7 @@ void LLPanelAvatarSecondLife::enableControls(BOOL self) // appears to reset the read only background color when // setEnable is called, for some reason LLTextEditor* about = LLUICtrlFactory::getTextEditorByName(this,"about"); - if (about) about->setReadOnlyBgColor(CLEAR); + if (about) about->setReadOnlyBgColor(LLColor4::transparent); } } @@ -466,7 +439,7 @@ BOOL LLPanelAvatarSecondLife::postBuild(void) childSetVisible("online_unknown",FALSE); childSetVisible("online_no",FALSE); - childSetAction("Show on Map", LLPanelAvatar::onClickTrack, getPanelAvatar()); + childSetAction("Find on Map", LLPanelAvatar::onClickTrack, getPanelAvatar()); childSetAction("Instant Message...", LLPanelAvatar::onClickIM, getPanelAvatar()); childSetAction("Add Friend...", LLPanelAvatar::onClickAddFriend, getPanelAvatar()); @@ -753,10 +726,10 @@ void LLPanelAvatarAdvanced::enableControls(BOOL self) // This is because the LLTextEditor // appears to reset the read only background color when // setEnable is called, for some reason - if (mWantToEdit) mWantToEdit->setReadOnlyBgColor(CLEAR); - if (mSkillsEdit) mSkillsEdit->setReadOnlyBgColor(CLEAR); + if (mWantToEdit) mWantToEdit->setReadOnlyBgColor(LLColor4::transparent); + if (mSkillsEdit) mSkillsEdit->setReadOnlyBgColor(LLColor4::transparent); LLLineEditor* languages_edit = (LLLineEditor*)getChildByName("languages_edit"); - languages_edit->setReadOnlyBgColor(CLEAR); + languages_edit->setReadOnlyBgColor(LLColor4::transparent); } } @@ -831,7 +804,7 @@ void LLPanelAvatarNotes::refresh() void LLPanelAvatarNotes::clearControls() { - childSetText("notes edit", LOADING_MSG); + childSetText("notes edit", childGetText("Loading")); childSetEnabled("notes edit", false); } @@ -1495,8 +1468,8 @@ void LLPanelAvatar::setAvatarID(const LLUUID &avatar_id, const LLString &name, childSetEnabled("Offer Teleport...",FALSE); childSetVisible("drop target",FALSE); childSetEnabled("drop target",FALSE); - childSetVisible("Show on Map",FALSE); - childSetEnabled("Show on Map",FALSE); + childSetVisible("Find on Map",FALSE); + childSetEnabled("Find on Map",FALSE); childSetVisible("Add Friend...",FALSE); childSetEnabled("Add Friend...",FALSE); childSetVisible("Pay...",FALSE); @@ -1512,28 +1485,27 @@ void LLPanelAvatar::setAvatarID(const LLUUID &avatar_id, const LLString &name, childSetVisible("Instant Message...",TRUE); childSetEnabled("Instant Message...",FALSE); - childSetToolTip("Instant Message...",IM_ENABLED_TOOLTIP); childSetVisible("Mute",TRUE); childSetEnabled("Mute",FALSE); childSetVisible("drop target",TRUE); childSetEnabled("drop target",FALSE); - childSetVisible("Show on Map",TRUE); + childSetVisible("Find on Map",TRUE); // Note: we don't always know online status, so always allow gods to try to track BOOL enable_track = gAgent.isGodlike() || is_agent_mappable(mAvatarID); - childSetEnabled("Show on Map",enable_track); + childSetEnabled("Find on Map",enable_track); if (!mIsFriend) { - childSetToolTip("Show on Map",childGetValue("ShowOnMapNonFriend").asString()); + childSetToolTip("Find on Map",childGetValue("ShowOnMapNonFriend").asString()); } else if (ONLINE_STATUS_YES != online_status) { - childSetToolTip("Show on Map",childGetValue("ShowOnMapFriendOffline").asString()); + childSetToolTip("Find on Map",childGetValue("ShowOnMapFriendOffline").asString()); } else { - childSetToolTip("Show on Map",childGetValue("ShowOnMapFriendOnline").asString()); + childSetToolTip("Find on Map",childGetValue("ShowOnMapFriendOnline").asString()); } childSetVisible("Add Friend...", true); childSetEnabled("Add Friend...", !avatar_is_friend); @@ -1775,7 +1747,7 @@ void LLPanelAvatar::sendAvatarNotesUpdate() std::string notes = mPanelNotes->childGetValue("notes edit").asString(); if (!mHaveNotes - && (notes.empty() || notes == LOADING_MSG)) + && (notes.empty() || notes == childGetText("Loading"))) { // no notes from server and no user updates return; @@ -1856,11 +1828,6 @@ void LLPanelAvatar::processAvatarPropertiesReply(LLMessageSystem *msg, void**) allow_publish = (flags & AVATAR_ALLOW_PUBLISH); online = (flags & AVATAR_ONLINE); - EOnlineStatus online_status = (online) ? ONLINE_STATUS_YES : ONLINE_STATUS_NO; - - self->setOnlineStatus(online_status); - - self->mPanelWeb->setWebURL(std::string(profile_url)); U8 caption_index = 0; LLString caption_text; charter_member_size = msg->getSize("PropertiesData", "CharterMember"); @@ -1875,12 +1842,6 @@ void LLPanelAvatar::processAvatarPropertiesReply(LLMessageSystem *msg, void**) caption_text = caption; } - LLTextureCtrl* image_ctrl = LLUICtrlFactory::getTexturePickerByName(self->mPanelSecondLife,"img"); - if(image_ctrl) - { - image_ctrl->setImageAssetID(image_id); - } - self->childSetValue("about", about_text); if(caption_text.empty()) { @@ -1923,10 +1884,23 @@ void LLPanelAvatar::processAvatarPropertiesReply(LLMessageSystem *msg, void**) self->mPanelSecondLife->childSetValue("acct", caption_text); self->mPanelSecondLife->childSetValue("born", born_on); - + + EOnlineStatus online_status = (online) ? ONLINE_STATUS_YES : ONLINE_STATUS_NO; + + self->setOnlineStatus(online_status); + + self->mPanelWeb->setWebURL(std::string(profile_url)); + + LLTextureCtrl* image_ctrl = LLUICtrlFactory::getTexturePickerByName(self->mPanelSecondLife,"img"); + if(image_ctrl) + { + image_ctrl->setImageAssetID(image_id); + } + self->childSetValue("about", about_text); + self->mPanelSecondLife->setPartnerID(partner_id); self->mPanelSecondLife->updatePartnerName(); - + if (self->mPanelFirstLife) { // Teens don't get these diff --git a/linden/indra/newview/llpanelavatar.h b/linden/indra/newview/llpanelavatar.h index 05b18c5..d4b935f 100644 --- a/linden/indra/newview/llpanelavatar.h +++ b/linden/indra/newview/llpanelavatar.h @@ -2,6 +2,8 @@ * @file llpanelavatar.h * @brief LLPanelAvatar and related class definitions * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELAVATAR_H diff --git a/linden/indra/newview/llpanelclassified.cpp b/linden/indra/newview/llpanelclassified.cpp index 96adf06..0c3edf1 100644 --- a/linden/indra/newview/llpanelclassified.cpp +++ b/linden/indra/newview/llpanelclassified.cpp @@ -2,6 +2,8 @@ * @file llpanelclassified.cpp * @brief LLPanelClassified class implementation * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Display of a classified used both for the global view in the @@ -352,8 +355,7 @@ void LLPanelClassified::initNewClassified() // delay commit until user hits save // sendClassifiedInfoUpdate(); - mUpdateBtn->setLabelSelected("Publish..."); - mUpdateBtn->setLabelUnselected("Publish..."); + mUpdateBtn->setLabel(childGetText("publish_txt")); } @@ -572,8 +574,8 @@ void LLPanelClassified::processClassifiedInfoReply(LLMessageSystem *msg, void ** self->mPosGlobal = pos_global; // Update UI controls - self->mNameEditor->setText(name); - self->mDescEditor->setText(desc); + self->mNameEditor->setText(LLString(name)); + self->mDescEditor->setText(LLString(desc)); self->mSnapshotCtrl->setImageAssetID(snapshot_id); self->mLocationEditor->setText(location_text); self->mLocationChanged = false; @@ -593,8 +595,7 @@ void LLPanelClassified::processClassifiedInfoReply(LLMessageSystem *msg, void ** // If we got data from the database, we know the listing is paid for. self->mPaidFor = TRUE; - self->mUpdateBtn->setLabelSelected("Update"); - self->mUpdateBtn->setLabelUnselected("Update"); + self->mUpdateBtn->setLabel(self->childGetText("update_txt")); } } diff --git a/linden/indra/newview/llpanelclassified.h b/linden/indra/newview/llpanelclassified.h index f0151df..56c2fbd 100644 --- a/linden/indra/newview/llpanelclassified.h +++ b/linden/indra/newview/llpanelclassified.h @@ -2,6 +2,8 @@ * @file llpanelclassified.h * @brief LLPanelClassified class definition * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Display of a classified used both for the global view in the diff --git a/linden/indra/newview/llpanelcontents.cpp b/linden/indra/newview/llpanelcontents.cpp index 73c1cac..50ff7bd 100644 --- a/linden/indra/newview/llpanelcontents.cpp +++ b/linden/indra/newview/llpanelcontents.cpp @@ -2,6 +2,8 @@ * @file llpanelcontents.cpp * @brief Object contents panel in the tools floater. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -135,11 +138,8 @@ void LLPanelContents::getState(LLViewerObject *objectp ) void LLPanelContents::refresh() { - LLViewerObject* object = gSelectMgr->getSelection()->getFirstRootObject(); - if(!object) - { - object = gSelectMgr->getSelection()->getFirstObject(); - } + const BOOL children_ok = TRUE; + LLViewerObject* object = gSelectMgr->getSelection()->getFirstRootObject(children_ok); getState(object); if (mPanelInventory) @@ -157,11 +157,8 @@ void LLPanelContents::refresh() // static void LLPanelContents::onClickNewScript(void *userdata) { - LLViewerObject* object = gSelectMgr->getSelection()->getFirstRootObject(); - if(!object) - { - object = gSelectMgr->getSelection()->getFirstObject(); - } + const BOOL children_ok = TRUE; + LLViewerObject* object = gSelectMgr->getSelection()->getFirstRootObject(children_ok); if(object) { LLPermissions perm; diff --git a/linden/indra/newview/llpanelcontents.h b/linden/indra/newview/llpanelcontents.h index da2f5f5..98e53d6 100644 --- a/linden/indra/newview/llpanelcontents.h +++ b/linden/indra/newview/llpanelcontents.h @@ -2,6 +2,8 @@ * @file llpanelcontents.h * @brief Object contents panel in the tools floater. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELCONTENTS_H diff --git a/linden/indra/newview/llpaneldebug.cpp b/linden/indra/newview/llpaneldebug.cpp index 0293c24..d090c03 100644 --- a/linden/indra/newview/llpaneldebug.cpp +++ b/linden/indra/newview/llpaneldebug.cpp @@ -2,6 +2,8 @@ * @file llpaneldebug.cpp * @brief Debug preferences panel for preferences floater * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llpaneldebug.h b/linden/indra/newview/llpaneldebug.h index cfd4db8..2af3667 100644 --- a/linden/indra/newview/llpaneldebug.h +++ b/linden/indra/newview/llpaneldebug.h @@ -2,6 +2,8 @@ * @file llpaneldebug.h * @brief Debug preferences panel for preferences floater * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELDEBUG_H diff --git a/linden/indra/newview/llpaneldirbrowser.cpp b/linden/indra/newview/llpaneldirbrowser.cpp index 232ee35..3e79c9d 100644 --- a/linden/indra/newview/llpaneldirbrowser.cpp +++ b/linden/indra/newview/llpaneldirbrowser.cpp @@ -2,6 +2,8 @@ * @file llpaneldirbrowser.cpp * @brief LLPanelDirBrowser class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Base class for the various search panels/results browsers diff --git a/linden/indra/newview/llpaneldirbrowser.h b/linden/indra/newview/llpaneldirbrowser.h index bd0f309..aa19721 100644 --- a/linden/indra/newview/llpaneldirbrowser.h +++ b/linden/indra/newview/llpaneldirbrowser.h @@ -2,6 +2,8 @@ * @file llpaneldirbrowser.h * @brief LLPanelDirBrowser class definition * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Base class for the various search panels/results browsers diff --git a/linden/indra/newview/llpaneldirclassified.cpp b/linden/indra/newview/llpaneldirclassified.cpp index 276b608..50bdfda 100644 --- a/linden/indra/newview/llpaneldirclassified.cpp +++ b/linden/indra/newview/llpaneldirclassified.cpp @@ -2,6 +2,8 @@ * @file llpaneldirclassified.cpp * @brief Classified panel in the Find directory. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llpaneldirclassified.h b/linden/indra/newview/llpaneldirclassified.h index f8f3c76..878445a 100644 --- a/linden/indra/newview/llpaneldirclassified.h +++ b/linden/indra/newview/llpaneldirclassified.h @@ -2,6 +2,8 @@ * @file llpaneldirclassified.h * @brief Classified panel in the Find directory. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELDIRCLASSIFIED_H diff --git a/linden/indra/newview/llpaneldirevents.cpp b/linden/indra/newview/llpaneldirevents.cpp index f60c113..861c54d 100644 --- a/linden/indra/newview/llpaneldirevents.cpp +++ b/linden/indra/newview/llpaneldirevents.cpp @@ -2,6 +2,8 @@ * @file llpaneldirevents.cpp * @brief Events listing in the Find directory. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llpaneldirevents.h b/linden/indra/newview/llpaneldirevents.h index d962c5f..cc1fe6a 100644 --- a/linden/indra/newview/llpaneldirevents.h +++ b/linden/indra/newview/llpaneldirevents.h @@ -2,6 +2,8 @@ * @file llpaneldirevents.h * @brief Events listing in the Find directory. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELDIREVENTS_H diff --git a/linden/indra/newview/llpaneldirfind.cpp b/linden/indra/newview/llpaneldirfind.cpp index 38669f8..73643bf 100644 --- a/linden/indra/newview/llpaneldirfind.cpp +++ b/linden/indra/newview/llpaneldirfind.cpp @@ -2,6 +2,8 @@ * @file llpaneldirfind.cpp * @brief The "Find All" panel in the Find directory. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -117,7 +120,17 @@ void LLPanelDirFind::onClickSearch(void *userdata) scope |= DFQ_EVENTS; // events scope |= DFQ_GROUPS; // groups - if (!gSavedSettings.getBOOL("ShowMatureFindAll") || gAgent.mAccess <= SIM_ACCESS_PG) scope |= DFQ_PG_SIMS_ONLY; + BOOL filter_mature = (!gSavedSettings.getBOOL("ShowMatureFindAll") || + gAgent.mAccess <= SIM_ACCESS_PG || + !self->childGetValue("incmature").asBoolean() ); + + if ( filter_mature ) + { + scope |= DFQ_PG_SIMS_ONLY; + scope |= DFQ_PG_EVENTS_ONLY; + scope |= DFQ_FILTER_MATURE; + scope |= DFQ_PG_PARCELS_ONLY; + } // send the message LLMessageSystem *msg = gMessageSystem; @@ -125,8 +138,6 @@ void LLPanelDirFind::onClickSearch(void *userdata) sendDirFindQuery(msg, self->mSearchID, self->childGetValue("name").asString(), scope, start_row); // Also look up classified ads. JC 12/2005 - BOOL filter_mature = !gSavedSettings.getBOOL("ShowMatureFindAll"); - if (gAgent.mAccess <= SIM_ACCESS_PG) filter_mature = TRUE; BOOL filter_auto_renew = FALSE; U32 classified_flags = pack_classified_flags(filter_mature, filter_auto_renew); msg->newMessage("DirClassifiedQuery"); @@ -141,11 +152,15 @@ void LLPanelDirFind::onClickSearch(void *userdata) msg->addS32("QueryStart", 0); gAgent.sendReliableMessage(); - U32 query_flags = DFQ_DWELL_SORT; - if (!gSavedSettings.getBOOL("ShowMatureFindAll") || gAgent.mAccess <= SIM_ACCESS_PG) query_flags |= DFQ_PG_SIMS_ONLY; - // Need to use separate find places query because places are // sent using the more compact DirPlacesReply message. + U32 query_flags = DFQ_DWELL_SORT; + if ( filter_mature ) + { + query_flags |= DFQ_PG_SIMS_ONLY; + query_flags |= DFQ_PG_PARCELS_ONLY; // FWIW, currently DFQ_PG_PARCELS_ONLY is only supported + query_flags |= DFQ_FILTER_MATURE; + } msg->newMessage("DirPlacesQuery"); msg->nextBlock("AgentData"); msg->addUUID("AgentID", gAgent.getID() ); diff --git a/linden/indra/newview/llpaneldirfind.h b/linden/indra/newview/llpaneldirfind.h index d0a1247..57bdadb 100644 --- a/linden/indra/newview/llpaneldirfind.h +++ b/linden/indra/newview/llpaneldirfind.h @@ -2,6 +2,8 @@ * @file llpaneldirfind.h * @brief The "Find All" panel in the Find directory. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELDIRFIND_H diff --git a/linden/indra/newview/llpaneldirgroups.cpp b/linden/indra/newview/llpaneldirgroups.cpp index d42cf96..e9bcb53 100644 --- a/linden/indra/newview/llpaneldirgroups.cpp +++ b/linden/indra/newview/llpaneldirgroups.cpp @@ -2,6 +2,8 @@ * @file llpaneldirgroups.cpp * @brief Groups panel in the Find directory. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llpaneldirgroups.h b/linden/indra/newview/llpaneldirgroups.h index e4fe6a5..9893a1f 100644 --- a/linden/indra/newview/llpaneldirgroups.h +++ b/linden/indra/newview/llpaneldirgroups.h @@ -2,6 +2,8 @@ * @file llpaneldirgroups.h * @brief Groups panel in the Find directory. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLPANELDIRGROUPS_H diff --git a/linden/indra/newview/llpaneldirland.cpp b/linden/indra/newview/llpaneldirland.cpp index d5883dc..3c8e5cc 100644 --- a/linden/indra/newview/llpaneldirland.cpp +++ b/linden/indra/newview/llpaneldirland.cpp @@ -2,6 +2,8 @@ * @file llpaneldirland.cpp * @brief Land For Sale and Auction in the Find directory. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llpaneldirland.h b/linden/indra/newview/llpaneldirland.h index 93dbee1..cabf352 100644 --- a/linden/indra/newview/llpaneldirland.h +++ b/linden/indra/newview/llpaneldirland.h @@ -2,6 +2,8 @@ * @file llpaneldirland.h * @brief Land For Sale and Auction in the Find directory. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELDIRLAND_H diff --git a/linden/indra/newview/llpaneldirpeople.cpp b/linden/indra/newview/llpaneldirpeople.cpp index ba94ea9..b734a49 100644 --- a/linden/indra/newview/llpaneldirpeople.cpp +++ b/linden/indra/newview/llpaneldirpeople.cpp @@ -2,6 +2,8 @@ * @file llpaneldirpeople.cpp * @brief People (online and off) in the Find directory. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llpaneldirpeople.h b/linden/indra/newview/llpaneldirpeople.h index ee8ea19..02ea456 100644 --- a/linden/indra/newview/llpaneldirpeople.h +++ b/linden/indra/newview/llpaneldirpeople.h @@ -2,6 +2,8 @@ * @file llpaneldirpeople.h * @brief People (online and off) in the Find directory. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELDIRPEOPLE_H diff --git a/linden/indra/newview/llpaneldirplaces.cpp b/linden/indra/newview/llpaneldirplaces.cpp index 1a9a61f..5802992 100644 --- a/linden/indra/newview/llpaneldirplaces.cpp +++ b/linden/indra/newview/llpaneldirplaces.cpp @@ -2,6 +2,8 @@ * @file llpaneldirplaces.cpp * @brief "Places" panel in the Find directory (not popular places, just places) * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llpaneldirplaces.h b/linden/indra/newview/llpaneldirplaces.h index d8a0e4e..f8aa6dd 100644 --- a/linden/indra/newview/llpaneldirplaces.h +++ b/linden/indra/newview/llpaneldirplaces.h @@ -2,6 +2,8 @@ * @file llpaneldirplaces.h * @brief "Places" panel in the Find directory (not popular places, just places) * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELDIRPLACES_H diff --git a/linden/indra/newview/llpaneldirpopular.cpp b/linden/indra/newview/llpaneldirpopular.cpp index 5577ca0..39465d5 100644 --- a/linden/indra/newview/llpaneldirpopular.cpp +++ b/linden/indra/newview/llpaneldirpopular.cpp @@ -2,6 +2,8 @@ * @file llpaneldirpopular.cpp * @brief Popular places as measured by dwell. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llpaneldirpopular.h b/linden/indra/newview/llpaneldirpopular.h index 1d70f8a..b884b36 100644 --- a/linden/indra/newview/llpaneldirpopular.h +++ b/linden/indra/newview/llpaneldirpopular.h @@ -2,6 +2,8 @@ * @file llpaneldirpopular.h * @brief Popular places in the world, as measured by dwell. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELDIRPOPULAR_H diff --git a/linden/indra/newview/llpaneldisplay.cpp b/linden/indra/newview/llpaneldisplay.cpp index 4a03900..3b2edcc 100644 --- a/linden/indra/newview/llpaneldisplay.cpp +++ b/linden/indra/newview/llpaneldisplay.cpp @@ -2,6 +2,8 @@ * @file llpaneldisplay.cpp * @brief Display preferences for the preferences floater * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -387,20 +390,20 @@ void LLPanelDisplay::onCommitAutoDetectAspect(LLUICtrl *ctrl, void *data) if (auto_detect) { - char aspect[100]; /*Flawfinder: ignore*/ S32 numerator = 0; S32 denominator = 0; // clear any aspect ratio override gViewerWindow->mWindow->setNativeAspectRatio(0.f); fractionFromDecimal(gViewerWindow->mWindow->getNativeAspectRatio(), numerator, denominator); + LLString aspect; if (numerator != 0) { - snprintf(aspect, sizeof(aspect), "%d:%d", numerator, denominator); /* Flawfinder: ignore */ + aspect = llformat("%d:%d", numerator, denominator); } else { - snprintf(aspect, sizeof(aspect), "%.3f", gViewerWindow->mWindow->getNativeAspectRatio()); /* Flawfinder: ignore */ + aspect = llformat("%.3f", gViewerWindow->mWindow->getNativeAspectRatio()); } panel->mCtrlAspectRatio->setLabel(aspect); diff --git a/linden/indra/newview/llpaneldisplay.h b/linden/indra/newview/llpaneldisplay.h index 80aae66..cf14fa6 100644 --- a/linden/indra/newview/llpaneldisplay.h +++ b/linden/indra/newview/llpaneldisplay.h @@ -2,6 +2,8 @@ * @file llpaneldisplay.h * @brief Display preferences for the preferences floater * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELDISPLAY_H diff --git a/linden/indra/newview/llpanelevent.cpp b/linden/indra/newview/llpanelevent.cpp index 1f2fb37..7812a48 100644 --- a/linden/indra/newview/llpanelevent.cpp +++ b/linden/indra/newview/llpanelevent.cpp @@ -2,6 +2,8 @@ * @file llpanelevent.cpp * @brief Display for events in the finder * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -73,8 +76,7 @@ BOOL LLPanelEvent::postBuild() mTBCategory = LLViewerUICtrlFactory::getTextBoxByName(this, "event_category"); mTBCategory->setColor(gColors.getColor( "LabelSelectedColor" )); - mMatureText = LLViewerUICtrlFactory::getTextBoxByName(this, "event_mature"); - mMatureText->setColor(gColors.getColor( "LabelSelectedColor" )); + childSetColor("event_mature", gColors.getColor( "LabelSelectedColor" )); mTBDate = LLViewerUICtrlFactory::getTextBoxByName(this, "event_date"); mTBDate->setColor(gColors.getColor( "LabelSelectedColor" )); @@ -165,26 +167,21 @@ void LLPanelEvent::processEventInfoReply(LLMessageSystem *msg, void **) { continue; } - char buffer[256]; /*Flawfinder: ignore*/ - self->mEventInfo.unpack(msg); self->mTBName->setText(self->mEventInfo.mName); self->mTBCategory->setText(self->mEventInfo.mCategoryStr); self->mTBDate->setText(self->mEventInfo.mTimeStr); self->mTBDesc->setText(self->mEventInfo.mDesc); - snprintf(buffer, sizeof(buffer), "%d:%.2d", self->mEventInfo.mDuration / 60, self->mEventInfo.mDuration % 60); /* Flawfinder: ignore */ - - self->mTBDuration->setText(buffer); + self->mTBDuration->setText(llformat("%d:%.2d", self->mEventInfo.mDuration / 60, self->mEventInfo.mDuration % 60)); if (!self->mEventInfo.mHasCover) { - self->mTBCover->setText("none"); + self->mTBCover->setText(self->childGetText("none")); } else { - snprintf(buffer, sizeof(buffer), "%d", self->mEventInfo.mCover); /* Flawfinder: ignore */ - self->mTBCover->setText(buffer); + self->mTBCover->setText(llformat("%d", self->mEventInfo.mCover)); } F32 global_x = (F32)self->mEventInfo.mPosGlobal.mdV[VX]; @@ -194,16 +191,18 @@ void LLPanelEvent::processEventInfoReply(LLMessageSystem *msg, void **) S32 region_y = llround(global_y) % REGION_WIDTH_UNITS; S32 region_z = llround((F32)self->mEventInfo.mPosGlobal.mdV[VZ]); - snprintf(buffer, sizeof(buffer), "%s (%d, %d, %d)", self->mEventInfo.mSimName.c_str(), region_x, region_y, region_z); /* Flawfinder: ignore */ - self->mTBLocation->setText(buffer); + LLString desc = self->mEventInfo.mSimName + llformat(" (%d, %d, %d)", region_x, region_y, region_z); + self->mTBLocation->setText(desc); if (self->mEventInfo.mEventFlags & EVENT_FLAG_MATURE) { - self->mMatureText->setText("Yes"); + self->childSetVisible("event_mature_yes", TRUE); + self->childSetVisible("event_mature_no", FALSE); } else { - self->mMatureText->setText("No"); + self->childSetVisible("event_mature_yes", FALSE); + self->childSetVisible("event_mature_no", TRUE); } if (self->mEventInfo.mUnixTime < time_corrected()) @@ -217,13 +216,11 @@ void LLPanelEvent::processEventInfoReply(LLMessageSystem *msg, void **) if (gEventNotifier.hasNotification(self->mEventInfo.mID)) { - self->mNotifyBtn->setLabelSelected("Don't Notify"); - self->mNotifyBtn->setLabelUnselected("Don't Notify"); + self->mNotifyBtn->setLabel(self->childGetText("dont_notify")); } else { - self->mNotifyBtn->setLabelSelected("Notify"); - self->mNotifyBtn->setLabelUnselected("Notify"); + self->mNotifyBtn->setLabel(self->childGetText("notify")); } } } @@ -315,14 +312,12 @@ void LLPanelEvent::onClickNotify(void *data) if (!gEventNotifier.hasNotification(self->mEventID)) { gEventNotifier.add(self->mEventInfo); - self->mNotifyBtn->setLabelSelected("Don't Notify"); - self->mNotifyBtn->setLabelUnselected("Don't Notify"); + self->mNotifyBtn->setLabel(self->childGetText("dont_notify")); } else { gEventNotifier.remove(self->mEventInfo.mID); - self->mNotifyBtn->setLabelSelected("Notify"); - self->mNotifyBtn->setLabelUnselected("Notify"); + self->mNotifyBtn->setLabel(self->childGetText("notify")); } } diff --git a/linden/indra/newview/llpanelevent.h b/linden/indra/newview/llpanelevent.h index 5f92483..fa5afa5 100644 --- a/linden/indra/newview/llpanelevent.h +++ b/linden/indra/newview/llpanelevent.h @@ -2,6 +2,8 @@ * @file llpanelevent.h * @brief Display for events in the finder * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELEVENT_H @@ -72,7 +75,6 @@ protected: LLEventInfo mEventInfo; LLTextBox* mTBName; - LLTextBox* mMatureText; LLTextBox* mTBCategory; LLTextBox* mTBDate; LLTextBox* mTBDuration; diff --git a/linden/indra/newview/llpanelface.cpp b/linden/indra/newview/llpanelface.cpp index b48d8c7..63e25d9 100644 --- a/linden/indra/newview/llpanelface.cpp +++ b/linden/indra/newview/llpanelface.cpp @@ -2,6 +2,8 @@ * @file llpanelface.cpp * @brief Panel in the tools floater for editing face textures, colors, etc. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -252,35 +255,32 @@ void LLPanelFace::sendAlpha() } - -void LLPanelFace::sendTextureInfo() +struct LLPanelFaceSetTEFunctor : public LLSelectedTEFunctor { - S32 te; - LLViewerObject* object; - LLObjectSelectionHandle selection = gSelectMgr->getSelection(); - for ( selection->getFirstTE(&object, &te); object; selection->getNextTE(&object, &te) ) + LLPanelFaceSetTEFunctor(LLPanelFace* panel) : mPanel(panel) {} + virtual bool apply(LLViewerObject* object, S32 te) { BOOL valid; F32 value; - LLSpinCtrl* mCtrlTexScaleS = LLViewerUICtrlFactory::getSpinnerByName(this,"TexScaleU"); - LLSpinCtrl* mCtrlTexScaleT = LLViewerUICtrlFactory::getSpinnerByName(this,"TexScaleV"); - LLSpinCtrl* mCtrlTexOffsetS = LLViewerUICtrlFactory::getSpinnerByName(this,"TexOffsetU"); - LLSpinCtrl* mCtrlTexOffsetT = LLViewerUICtrlFactory::getSpinnerByName(this,"TexOffsetV"); - LLSpinCtrl* mCtrlTexRotation = LLViewerUICtrlFactory::getSpinnerByName(this,"TexRot"); - LLCheckBoxCtrl* mCheckFlipScaleS = LLViewerUICtrlFactory::getCheckBoxByName(this,"checkbox flip s"); - LLCheckBoxCtrl* mCheckFlipScaleT = LLViewerUICtrlFactory::getCheckBoxByName(this,"checkbox flip t"); - LLComboBox* mComboTexGen = LLViewerUICtrlFactory::getComboBoxByName(this,"combobox texgen"); - if (mCtrlTexScaleS) + LLSpinCtrl* ctrlTexScaleS = LLViewerUICtrlFactory::getSpinnerByName(mPanel,"TexScaleU"); + LLSpinCtrl* ctrlTexScaleT = LLViewerUICtrlFactory::getSpinnerByName(mPanel,"TexScaleV"); + LLSpinCtrl* ctrlTexOffsetS = LLViewerUICtrlFactory::getSpinnerByName(mPanel,"TexOffsetU"); + LLSpinCtrl* ctrlTexOffsetT = LLViewerUICtrlFactory::getSpinnerByName(mPanel,"TexOffsetV"); + LLSpinCtrl* ctrlTexRotation = LLViewerUICtrlFactory::getSpinnerByName(mPanel,"TexRot"); + LLCheckBoxCtrl* checkFlipScaleS = LLViewerUICtrlFactory::getCheckBoxByName(mPanel,"checkbox flip s"); + LLCheckBoxCtrl* checkFlipScaleT = LLViewerUICtrlFactory::getCheckBoxByName(mPanel,"checkbox flip t"); + LLComboBox* comboTexGen = LLViewerUICtrlFactory::getComboBoxByName(mPanel,"combobox texgen"); + if (ctrlTexScaleS) { - valid = !mCtrlTexScaleS->getTentative() || !mCheckFlipScaleS->getTentative(); + valid = !ctrlTexScaleS->getTentative() || !checkFlipScaleS->getTentative(); if (valid) { - value = mCtrlTexScaleS->get(); - if( mCheckFlipScaleS->get() ) + value = ctrlTexScaleS->get(); + if( checkFlipScaleS->get() ) { value = -value; } - if (mComboTexGen->getCurrentIndex() == 1) + if (comboTexGen->getCurrentIndex() == 1) { value *= 0.5f; } @@ -288,17 +288,17 @@ void LLPanelFace::sendTextureInfo() } } - if (mCtrlTexScaleT) + if (ctrlTexScaleT) { - valid = !mCtrlTexScaleT->getTentative() || !mCheckFlipScaleT->getTentative(); + valid = !ctrlTexScaleT->getTentative() || !checkFlipScaleT->getTentative(); if (valid) { - value = mCtrlTexScaleT->get(); - if( mCheckFlipScaleT->get() ) + value = ctrlTexScaleT->get(); + if( checkFlipScaleT->get() ) { value = -value; } - if (mComboTexGen->getCurrentIndex() == 1) + if (comboTexGen->getCurrentIndex() == 1) { value *= 0.5f; } @@ -306,41 +306,57 @@ void LLPanelFace::sendTextureInfo() } } - if (mCtrlTexOffsetS) + if (ctrlTexOffsetS) { - valid = !mCtrlTexOffsetS->getTentative(); + valid = !ctrlTexOffsetS->getTentative(); if (valid) { - value = mCtrlTexOffsetS->get(); + value = ctrlTexOffsetS->get(); object->setTEOffsetS( te, value ); } } - if (mCtrlTexOffsetT) + if (ctrlTexOffsetT) { - valid = !mCtrlTexOffsetT->getTentative(); + valid = !ctrlTexOffsetT->getTentative(); if (valid) { - value = mCtrlTexOffsetT->get(); + value = ctrlTexOffsetT->get(); object->setTEOffsetT( te, value ); } } - if (mCtrlTexRotation) + if (ctrlTexRotation) { - valid = !mCtrlTexRotation->getTentative(); + valid = !ctrlTexRotation->getTentative(); if (valid) { - value = mCtrlTexRotation->get() * DEG_TO_RAD; + value = ctrlTexRotation->get() * DEG_TO_RAD; object->setTERotation( te, value ); } } + return true; } +private: + LLPanelFace* mPanel; +}; - for ( object = gSelectMgr->getSelection()->getFirstObject(); object; object = gSelectMgr->getSelection()->getNextObject() ) +struct LLPanelFaceSendFunctor : public LLSelectedObjectFunctor +{ + virtual bool apply(LLViewerObject* object) { object->sendTEUpdate(); + return true; } +}; + +void LLPanelFace::sendTextureInfo() +{ + LLPanelFaceSetTEFunctor setfunc(this); + gSelectMgr->getSelection()->applyToTEs(&setfunc); + + LLPanelFaceSendFunctor sendfunc; + gSelectMgr->getSelection()->applyToObjects(&sendfunc); } void LLPanelFace::getState() @@ -368,43 +384,58 @@ void LLPanelFace::getState() } childSetEnabled("button apply",editable); + bool identical; + LLTextureCtrl* texture_ctrl = LLViewerUICtrlFactory::getTexturePickerByName(this,"texture control"); + // Texture - LLUUID id; - BOOL identical = gSelectMgr->selectionGetTexUUID(id); - LLTextureCtrl* mTextureCtrl = LLViewerUICtrlFactory::getTexturePickerByName(this,"texture control"); - if (identical) - { - // All selected have the same texture - if(mTextureCtrl){ - mTextureCtrl->setTentative( FALSE ); - mTextureCtrl->setEnabled( editable ); - mTextureCtrl->setImageAssetID( id ); - } - } - else { - if(mTextureCtrl){ - if( id.isNull() ) + LLUUID id; + struct f1 : public LLSelectedTEGetFunctor + { + LLUUID get(LLViewerObject* object, S32 te) + { + LLViewerImage* image = object->getTEImage(te); + return image ? image->getID() : LLUUID::null; + } + } func; + identical = gSelectMgr->getSelection()->getSelectedTEValue( &func, id ); + + if (identical) + { + // All selected have the same texture + if(texture_ctrl) { - // None selected - mTextureCtrl->setTentative( FALSE ); - mTextureCtrl->setEnabled( FALSE ); - mTextureCtrl->setImageAssetID( LLUUID::null ); + texture_ctrl->setTentative( FALSE ); + texture_ctrl->setEnabled( editable ); + texture_ctrl->setImageAssetID( id ); } - else + } + else + { + if(texture_ctrl) { - // Tentative: multiple selected with different textures - mTextureCtrl->setTentative( TRUE ); - mTextureCtrl->setEnabled( editable ); - mTextureCtrl->setImageAssetID( id ); + if( id.isNull() ) + { + // None selected + texture_ctrl->setTentative( FALSE ); + texture_ctrl->setEnabled( FALSE ); + texture_ctrl->setImageAssetID( LLUUID::null ); + } + else + { + // Tentative: multiple selected with different textures + texture_ctrl->setTentative( TRUE ); + texture_ctrl->setEnabled( editable ); + texture_ctrl->setImageAssetID( id ); + } } } } - + LLAggregatePermissions texture_perms; - if(mTextureCtrl) + if(texture_ctrl) { -// mTextureCtrl->setValid( editable ); +// texture_ctrl->setValid( editable ); if (gSelectMgr->selectGetAggregateTexturePermissions(texture_perms)) { @@ -414,11 +445,11 @@ void LLPanelFace::getState() BOOL can_transfer = texture_perms.getValue(PERM_TRANSFER) == LLAggregatePermissions::AP_EMPTY || texture_perms.getValue(PERM_TRANSFER) == LLAggregatePermissions::AP_ALL; - mTextureCtrl->setCanApplyImmediately(can_copy && can_transfer); + texture_ctrl->setCanApplyImmediately(can_copy && can_transfer); } else { - mTextureCtrl->setCanApplyImmediately(FALSE); + texture_ctrl->setCanApplyImmediately(FALSE); } } @@ -427,7 +458,14 @@ void LLPanelFace::getState() childSetEnabled("tex scale",editable); //mLabelTexScale->setEnabled( editable ); F32 scale_s = 1.f; - identical = allFacesSameValue( &LLPanelFace::valueScaleS, &scale_s ); + struct f2 : public LLSelectedTEGetFunctor + { + F32 get(LLViewerObject* object, S32 face) + { + return object->getTE(face)->mScaleS; + } + } func; + identical = gSelectMgr->getSelection()->getSelectedTEValue( &func, scale_s ); childSetValue("TexScaleU",editable ? llabs(scale_s) : 0); childSetTentative("TexScaleU",LLSD((BOOL)(!identical))); childSetEnabled("TexScaleU",editable); @@ -438,7 +476,14 @@ void LLPanelFace::getState() { F32 scale_t = 1.f; - identical = allFacesSameValue( &LLPanelFace::valueScaleT, &scale_t ); + struct f3 : public LLSelectedTEGetFunctor + { + F32 get(LLViewerObject* object, S32 face) + { + return object->getTE(face)->mScaleS; + } + } func; + identical = gSelectMgr->getSelection()->getSelectedTEValue( &func, scale_t ); childSetValue("TexScaleV",llabs(editable ? llabs(scale_t) : 0)); childSetTentative("TexScaleV",LLSD((BOOL)(!identical))); @@ -452,7 +497,14 @@ void LLPanelFace::getState() { childSetEnabled("tex offset",editable); F32 offset_s = 0.f; - identical = allFacesSameValue( &LLPanelFace::valueOffsetS, &offset_s ); + struct f4 : public LLSelectedTEGetFunctor + { + F32 get(LLViewerObject* object, S32 face) + { + return object->getTE(face)->mOffsetS; + } + } func; + identical = gSelectMgr->getSelection()->getSelectedTEValue( &func, offset_s ); childSetValue("TexOffsetU", editable ? offset_s : 0); childSetTentative("TexOffsetU",!identical); childSetEnabled("TexOffsetU",editable); @@ -460,7 +512,14 @@ void LLPanelFace::getState() { F32 offset_t = 0.f; - identical = allFacesSameValue( &LLPanelFace::valueOffsetT, &offset_t ); + struct f5 : public LLSelectedTEGetFunctor + { + F32 get(LLViewerObject* object, S32 face) + { + return object->getTE(face)->mOffsetT; + } + } func; + identical = gSelectMgr->getSelection()->getSelectedTEValue( &func, offset_t ); childSetValue("TexOffsetV", editable ? offset_t : 0); childSetTentative("TexOffsetV",!identical); childSetEnabled("TexOffsetV",editable); @@ -470,7 +529,14 @@ void LLPanelFace::getState() { childSetEnabled("tex rotate",editable); F32 rotation = 0.f; - identical = allFacesSameValue( &LLPanelFace::valueTexRotation, &rotation ); + struct f6 : public LLSelectedTEGetFunctor + { + F32 get(LLViewerObject* object, S32 face) + { + return object->getTE(face)->mRotation; + } + } func; + identical = gSelectMgr->getSelection()->getSelectedTEValue( &func, rotation ); childSetValue("TexRot", editable ? rotation * RAD_TO_DEG : 0); childSetTentative("TexRot",!identical); childSetEnabled("TexRot",editable); @@ -481,7 +547,15 @@ void LLPanelFace::getState() LLColor4 color = LLColor4::white; if(mColorSwatch) { - identical = gSelectMgr->selectionGetColor(color); + struct f7 : public LLSelectedTEGetFunctor + { + LLColor4 get(LLViewerObject* object, S32 face) + { + return object->getTE(face)->getColor(); + } + } func; + identical = gSelectMgr->getSelection()->getSelectedTEValue( &func, color ); + mColorSwatch->setOriginal(color); mColorSwatch->set(color, TRUE); @@ -503,7 +577,14 @@ void LLPanelFace::getState() // Bump { F32 shinyf = 0.f; - identical = allFacesSameValue( &LLPanelFace::valueShiny, &shinyf ); + struct f8 : public LLSelectedTEGetFunctor + { + F32 get(LLViewerObject* object, S32 face) + { + return (F32)(object->getTE(face)->getShiny()); + } + } func; + identical = gSelectMgr->getSelection()->getSelectedTEValue( &func, shinyf ); LLCtrlSelectionInterface* combobox_shininess = childGetSelectionInterface("combobox shininess"); if (combobox_shininess) @@ -521,7 +602,14 @@ void LLPanelFace::getState() { F32 bumpf = 0.f; - identical = allFacesSameValue( &LLPanelFace::valueBump, &bumpf ); + struct f9 : public LLSelectedTEGetFunctor + { + F32 get(LLViewerObject* object, S32 face) + { + return (F32)(object->getTE(face)->getBumpmap()); + } + } func; + identical = gSelectMgr->getSelection()->getSelectedTEValue( &func, bumpf ); LLCtrlSelectionInterface* combobox_bumpiness = childGetSelectionInterface("combobox bumpiness"); if (combobox_bumpiness) @@ -539,7 +627,14 @@ void LLPanelFace::getState() { F32 genf = 0.f; - identical = allFacesSameValue( &LLPanelFace::valueTexGen, &genf); + struct f10 : public LLSelectedTEGetFunctor + { + F32 get(LLViewerObject* object, S32 face) + { + return (F32)(object->getTE(face)->getTexGen()); + } + } func; + identical = gSelectMgr->getSelection()->getSelectedTEValue( &func, genf ); S32 selected_texgen = ((S32) genf) >> TEM_TEX_GEN_SHIFT; LLCtrlSelectionInterface* combobox_texgen = childGetSelectionInterface("combobox texgen"); @@ -570,7 +665,14 @@ void LLPanelFace::getState() { F32 fullbrightf = 0.f; - identical = allFacesSameValue( &LLPanelFace::valueFullbright, &fullbrightf ); + struct f11 : public LLSelectedTEGetFunctor + { + F32 get(LLViewerObject* object, S32 face) + { + return (F32)(object->getTE(face)->getFullbright()); + } + } func; + identical = gSelectMgr->getSelection()->getSelectedTEValue( &func, fullbrightf ); childSetValue("checkbox fullbright",(S32)fullbrightf); childSetEnabled("checkbox fullbright",editable); @@ -583,9 +685,22 @@ void LLPanelFace::getState() } // Repeats per meter - F32 repeats = 1.f; - identical = allFacesSameValue( &LLPanelFace::valueRepeatsPerMeter, &repeats ); { + F32 repeats = 1.f; + struct f12 : public LLSelectedTEGetFunctor + { + F32 get(LLViewerObject* object, S32 face) + { + U32 s_axis = VX; + U32 t_axis = VY; + // BUG: Only repeats along S axis + // BUG: Only works for boxes. + LLPrimitive::getTESTAxes(face, &s_axis, &t_axis); + return object->getTE(face)->mScaleS / object->getScale().mV[s_axis]; + } + } func; + identical = gSelectMgr->getSelection()->getSelectedTEValue( &func, repeats ); + childSetValue("rptctrl", editable ? repeats : 0); childSetTentative("rptctrl",!identical); LLComboBox* mComboTexGen = LLViewerUICtrlFactory::getComboBoxByName(this,"combobox texgen"); @@ -603,12 +718,12 @@ void LLPanelFace::getState() clearCtrls(); // Disable non-UICtrls - LLTextureCtrl* mTextureCtrl = LLUICtrlFactory::getTexturePickerByName(this,"texture control"); - if(mTextureCtrl) + LLTextureCtrl* texture_ctrl = LLUICtrlFactory::getTexturePickerByName(this,"texture control"); + if(texture_ctrl) { - mTextureCtrl->setImageAssetID( LLUUID::null ); - mTextureCtrl->setEnabled( FALSE ); // this is a LLUICtrl, but we don't want it to have keyboard focus so we add it as a child, not a ctrl. -// mTextureCtrl->setValid(FALSE); + texture_ctrl->setImageAssetID( LLUUID::null ); + texture_ctrl->setEnabled( FALSE ); // this is a LLUICtrl, but we don't want it to have keyboard focus so we add it as a child, not a ctrl. +// texture_ctrl->setValid(FALSE); } LLColorSwatchCtrl* mColorSwatch = LLUICtrlFactory::getColorSwatchByName(this,"colorswatch"); if(mColorSwatch) @@ -638,115 +753,10 @@ void LLPanelFace::refresh() getState(); } - -BOOL LLPanelFace::allFacesSameValue( F32 (get_face_value(LLViewerObject*, S32)), F32 *value) -{ - LLViewerObject* object; - S32 te; - - // Get the value from the primary selected TE - F32 first_value = *value; - BOOL got_first = FALSE; - gSelectMgr->getSelection()->getPrimaryTE(&object, &te); - if (object) - { - first_value = get_face_value(object, te); - got_first = true; - } - - // Now iterate through all TEs to test for sameness - BOOL identical = TRUE; - LLObjectSelectionHandle selection = gSelectMgr->getSelection(); - for ( selection->getFirstTE(&object, &te); object; selection->getNextTE(&object, &te) ) - { - if (!got_first) - { - first_value = get_face_value(object, te); - got_first = true; - } - if ( get_face_value(object, te) != first_value ) - { - identical = FALSE; - break; - } - } - - *value = first_value; - return identical; -} - - // // Static functions // -// static -F32 LLPanelFace::valueRepeatsPerMeter(LLViewerObject* object, S32 face) -{ - U32 s_axis = VX; - U32 t_axis = VY; - - // BUG: Only repeats along S axis - // BUG: Only works for boxes. - gSelectMgr->getTESTAxes(object, face, &s_axis, &t_axis); - return object->getTE(face)->mScaleS / object->getScale().mV[s_axis]; -} - -// static -F32 LLPanelFace::valueScaleS(LLViewerObject* object, S32 face) -{ - return object->getTE(face)->mScaleS; -} - - -// static -F32 LLPanelFace::valueScaleT(LLViewerObject* object, S32 face) -{ - return object->getTE(face)->mScaleT; -} - -// static -F32 LLPanelFace::valueOffsetS(LLViewerObject* object, S32 face) -{ - return object->getTE(face)->mOffsetS; -} - -// static -F32 LLPanelFace::valueOffsetT(LLViewerObject* object, S32 face) -{ - return object->getTE(face)->mOffsetT; -} - -// static -F32 LLPanelFace::valueTexRotation(LLViewerObject* object, S32 face) -{ - return object->getTE(face)->mRotation; -} - -// static -F32 LLPanelFace::valueBump(LLViewerObject* object, S32 face) -{ - return (F32)(object->getTE(face)->getBumpmap()); -} - -// static -F32 LLPanelFace::valueTexGen(LLViewerObject* object, S32 face) -{ - return (F32)(object->getTE(face)->getTexGen()); -} - -// static -F32 LLPanelFace::valueShiny(LLViewerObject* object, S32 face) -{ - return (F32)(object->getTE(face)->getShiny()); -} - -// static -F32 LLPanelFace::valueFullbright(LLViewerObject* object, S32 face) -{ - return (F32)(object->getTE(face)->getFullbright()); -} - // static void LLPanelFace::onCommitColor(LLUICtrl* ctrl, void* userdata) @@ -808,13 +818,16 @@ void LLPanelFace::onCommitFullbright(LLUICtrl* ctrl, void* userdata) BOOL LLPanelFace::onDragTexture(LLUICtrl*, LLInventoryItem* item, void*) { BOOL accept = TRUE; - LLViewerObject* obj = gSelectMgr->getSelection()->getFirstRootObject(); - while(accept && obj) + for (LLObjectSelection::root_iterator iter = gSelectMgr->getSelection()->root_begin(); + iter != gSelectMgr->getSelection()->root_end(); iter++) { + LLSelectNode* node = *iter; + LLViewerObject* obj = node->getObject(); if(!LLToolDragAndDrop::isInventoryDropAcceptable(obj, item)) + { accept = FALSE; - else - obj = gSelectMgr->getSelection()->getNextRootObject(); + break; + } } return accept; } @@ -865,14 +878,10 @@ void LLPanelFace::onClickApply(void* userdata) } // commit the fit media texture to prim button -void LLPanelFace::onClickAutoFix(void* userdata) -{ - S32 te; - LLViewerObject* object; - // for all selected objects - LLObjectSelectionHandle selection = gSelectMgr->getSelection(); - for ( selection->getFirstTE(&object, &te); object; selection->getNextTE(&object, &te) ) +struct LLPanelFaceSetMediaFunctor : public LLSelectedTEFunctor +{ + virtual bool apply(LLViewerObject* object, S32 te) { // only do this if it's a media texture if ( object->getTE ( te )->getID() == LLMediaEngine::getInstance()->getImageUUID () ) @@ -892,13 +901,17 @@ void LLPanelFace::onClickAutoFix(void* userdata) object->setTEScaleT( te, scaleT ); // don't need to flip Y anymore since QT does this for us now. object->setTEOffsetS( te, -( 1.0f - scaleS ) / 2.0f ); object->setTEOffsetT( te, -( 1.0f - scaleT ) / 2.0f ); - }; - }; - }; + } + } + return true; + } +}; - // not clear why this is in a separate loop but i followed the patter from further up this file just in case. - for ( object = gSelectMgr->getSelection()->getFirstObject(); object; object = gSelectMgr->getSelection()->getNextObject() ) - { - object->sendTEUpdate(); - }; +void LLPanelFace::onClickAutoFix(void* userdata) +{ + LLPanelFaceSetMediaFunctor setfunc; + gSelectMgr->getSelection()->applyToTEs(&setfunc); + + LLPanelFaceSendFunctor sendfunc; + gSelectMgr->getSelection()->applyToObjects(&sendfunc); } diff --git a/linden/indra/newview/llpanelface.h b/linden/indra/newview/llpanelface.h index b41d0e5..d680129 100644 --- a/linden/indra/newview/llpanelface.h +++ b/linden/indra/newview/llpanelface.h @@ -2,6 +2,8 @@ * @file llpanelface.h * @brief Panel in the tools floater for editing face textures, colors, etc. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELFACE_H @@ -54,11 +57,6 @@ public: void refresh(); protected: - // Given a callback function that returns an F32, figures out - // if that F32 is the same for all selected faces. "value" - // contains the identical value, or the first object's value. - BOOL allFacesSameValue( F32 (get_face_value(LLViewerObject*, S32)), F32 *value); - void getState(); void sendTexture(); // applies and sends texture @@ -88,17 +86,6 @@ protected: static void onClickApply(void*); static void onClickAutoFix(void*); - - static F32 valueScaleS(LLViewerObject* object, S32 face); - static F32 valueScaleT(LLViewerObject* object, S32 face); - static F32 valueOffsetS(LLViewerObject* object, S32 face); - static F32 valueOffsetT(LLViewerObject* object, S32 face); - static F32 valueTexRotation(LLViewerObject* object, S32 face); - static F32 valueRepeatsPerMeter(LLViewerObject* object, S32 face); - static F32 valueBump(LLViewerObject* object, S32 face); - static F32 valueTexGen(LLViewerObject* object, S32 face); - static F32 valueShiny(LLViewerObject* object, S32 face); - static F32 valueFullbright(LLViewerObject* object, S32 face); }; #endif diff --git a/linden/indra/newview/llpanelgeneral.cpp b/linden/indra/newview/llpanelgeneral.cpp index 7d1c778..c64bce0 100644 --- a/linden/indra/newview/llpanelgeneral.cpp +++ b/linden/indra/newview/llpanelgeneral.cpp @@ -2,6 +2,8 @@ * @file llpanelgeneral.cpp * @brief General preferences panel in preferences floater * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -51,6 +54,7 @@ #include "llspinctrl.h" #include "lltextbox.h" #include "llui.h" +#include "llurlsimstring.h" #include "llviewercontrol.h" #include "viewer.h" diff --git a/linden/indra/newview/llpanelgeneral.h b/linden/indra/newview/llpanelgeneral.h index a9bc662..7c89d78 100644 --- a/linden/indra/newview/llpanelgeneral.h +++ b/linden/indra/newview/llpanelgeneral.h @@ -3,6 +3,8 @@ * @author James Cook * @brief General preferences panel in preferences floater * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELGENERAL_H diff --git a/linden/indra/newview/llpanelgroup.cpp b/linden/indra/newview/llpanelgroup.cpp index 5887cc0..99744c9 100644 --- a/linden/indra/newview/llpanelgroup.cpp +++ b/linden/indra/newview/llpanelgroup.cpp @@ -1,6 +1,8 @@ /** * @file llpanelgroup.cpp * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -165,11 +168,11 @@ LLPanelGroup::LLPanelGroup(const std::string& filename, mFactoryMap["roles_sub_tab"] = LLCallbackMap(LLPanelGroupRolesSubTab::createTab, &mID); mFactoryMap["actions_sub_tab"] = LLCallbackMap(LLPanelGroupActionsSubTab::createTab, &mID); + gGroupMgr->addObserver(this); + // Pass on construction of this panel to the control factory. gUICtrlFactory->buildPanel(this, filename, &getFactoryMap()); mFilename = filename; - - gGroupMgr->addObserver(this); } LLPanelGroup::~LLPanelGroup() @@ -342,7 +345,7 @@ void LLPanelGroup::tabChanged() if ( mApplyBtn ) { LLString mesg; - mApplyBtn->setEnabled(mAllowEdit && mCurrentTab->needsApply(mesg)); + mApplyBtn->setEnabled(mCurrentTab->needsApply(mesg)); } } @@ -611,6 +614,12 @@ void LLPanelGroup::draw() mRefreshTimer.stop(); childEnable("btn_refresh"); } + if (mCurrentTab) + { + LLString mesg; + childSetEnabled("btn_apply", mCurrentTab->needsApply(mesg)); + } + } void LLPanelGroup::refreshData() diff --git a/linden/indra/newview/llpanelgroup.h b/linden/indra/newview/llpanelgroup.h index 782f28a..19f43ec 100644 --- a/linden/indra/newview/llpanelgroup.h +++ b/linden/indra/newview/llpanelgroup.h @@ -1,6 +1,8 @@ /** * @file llpanelgroup.h * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELGROUP_H @@ -57,7 +60,7 @@ public: LLPanelGroup(const std::string& filename, const std::string& name, const LLUUID& group_id, - const std::string& initial_tab_selected = ""); + const std::string& initial_tab_selected = std::string()); virtual ~LLPanelGroup(); virtual BOOL postBuild(); diff --git a/linden/indra/newview/llpanelgroupgeneral.cpp b/linden/indra/newview/llpanelgroupgeneral.cpp index b443036..ba0895d 100644 --- a/linden/indra/newview/llpanelgroupgeneral.cpp +++ b/linden/indra/newview/llpanelgroupgeneral.cpp @@ -2,6 +2,8 @@ * @file llpanelgroupgeneral.cpp * @brief General information about a group. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -73,12 +76,12 @@ LLPanelGroupGeneral::LLPanelGroupGeneral(const std::string& name, mBtnJoinGroup(NULL), mListVisibleMembers(NULL), mCtrlShowInGroupList(NULL), - mCtrlPublishOnWeb(NULL), mCtrlMature(NULL), mCtrlOpenEnrollment(NULL), mCtrlEnrollmentFee(NULL), mSpinEnrollmentFee(NULL), mCtrlReceiveNotices(NULL), + mCtrlListGroup(NULL), mActiveTitleLabel(NULL), mComboActiveTitle(NULL) { @@ -153,13 +156,6 @@ BOOL LLPanelGroupGeneral::postBuild() mCtrlShowInGroupList->setCallbackUserData(this); } - mCtrlPublishOnWeb = (LLCheckBoxCtrl*) getChildByName("publish_on_web", recurse); - if (mCtrlPublishOnWeb) - { - mCtrlPublishOnWeb->setCommitCallback(onCommitAny); - mCtrlPublishOnWeb->setCallbackUserData(this); - } - mCtrlMature = (LLCheckBoxCtrl*) getChildByName("mature", recurse); if (mCtrlMature) { @@ -191,20 +187,31 @@ BOOL LLPanelGroupGeneral::postBuild() } BOOL accept_notices = FALSE; + BOOL list_in_profile = FALSE; LLGroupData data; if(gAgent.getGroupData(mGroupID,data)) { accept_notices = data.mAcceptNotices; + list_in_profile = data.mListInProfile; } mCtrlReceiveNotices = (LLCheckBoxCtrl*) getChildByName("receive_notices", recurse); if (mCtrlReceiveNotices) { - mCtrlReceiveNotices->setCommitCallback(onReceiveNotices); + mCtrlReceiveNotices->setCommitCallback(onCommitUserOnly); mCtrlReceiveNotices->setCallbackUserData(this); mCtrlReceiveNotices->set(accept_notices); mCtrlReceiveNotices->setEnabled(data.mID.notNull()); } + mCtrlListGroup = (LLCheckBoxCtrl*) getChildByName("list_groups_in_profile", recurse); + if (mCtrlListGroup) + { + mCtrlListGroup->setCommitCallback(onCommitUserOnly); + mCtrlListGroup->setCallbackUserData(this); + mCtrlListGroup->set(list_in_profile); + mCtrlListGroup->setEnabled(data.mID.notNull()); + } + mActiveTitleLabel = (LLTextBox*) getChildByName("active_title_label", recurse); mComboActiveTitle = (LLComboBox*) getChildByName("active_title", recurse); @@ -238,7 +245,6 @@ BOOL LLPanelGroupGeneral::postBuild() mEditCharter->setEnabled(TRUE); mCtrlShowInGroupList->setEnabled(TRUE); - mCtrlPublishOnWeb->setEnabled(TRUE); mCtrlMature->setEnabled(TRUE); mCtrlOpenEnrollment->setEnabled(TRUE); mCtrlEnrollmentFee->setEnabled(TRUE); @@ -261,6 +267,15 @@ void LLPanelGroupGeneral::onCommitAny(LLUICtrl* ctrl, void* data) } // static +void LLPanelGroupGeneral::onCommitUserOnly(LLUICtrl* ctrl, void* data) +{ + LLPanelGroupGeneral* self = (LLPanelGroupGeneral*)data; + self->mChanged = TRUE; + self->notifyObservers(); +} + + +// static void LLPanelGroupGeneral::onCommitEnrollment(LLUICtrl* ctrl, void* data) { onCommitAny(ctrl, data); @@ -361,16 +376,6 @@ void LLPanelGroupGeneral::joinDlgCB(S32 which, void *userdata) } // static -void LLPanelGroupGeneral::onReceiveNotices(LLUICtrl* ctrl, void* data) -{ - LLPanelGroupGeneral* self = (LLPanelGroupGeneral*)data; - LLCheckBoxCtrl* check = (LLCheckBoxCtrl*)ctrl; - - if(!self) return; - gAgent.setGroupAcceptNotices(self->mGroupID, check->get()); -} - -// static void LLPanelGroupGeneral::openProfile(void* data) { LLPanelGroupGeneral* self = (LLPanelGroupGeneral*)data; @@ -427,90 +432,92 @@ void LLPanelGroupGeneral::draw() bool LLPanelGroupGeneral::apply(LLString& mesg) { - if (!mAllowEdit) - { - llwarns << "LLPanelGroupGeneral::apply() called with false mAllowEdit" - << llendl; - return true; - } + BOOL has_power_in_group = gAgent.hasPowerInGroup(mGroupID,GP_GROUP_CHANGE_IDENTITY); - llinfos << "LLPanelGroupGeneral::apply" << llendl; - if (mGroupID.isNull()) + if (has_power_in_group || mGroupID.isNull()) { - // Validate the group name length. - S32 group_name_len = mGroupNameEditor->getText().size(); - if ( group_name_len < DB_GROUP_NAME_MIN_LEN - || group_name_len > DB_GROUP_NAME_STR_LEN) + llinfos << "LLPanelGroupGeneral::apply" << llendl; + if (mGroupID.isNull()) { - std::ostringstream temp_error; - temp_error << "A group name must be between " << DB_GROUP_NAME_MIN_LEN - << " and " << DB_GROUP_NAME_STR_LEN << " characters."; - mesg = temp_error.str(); - return false; - } - - LLString::format_map_t args; - args["[MESSAGE]"] = mConfirmGroupCreateStr; - gViewerWindow->alertXml("GenericAlertYesCancel", args, - createGroupCallback,this); + // Validate the group name length. + S32 group_name_len = mGroupNameEditor->getText().size(); + if ( group_name_len < DB_GROUP_NAME_MIN_LEN + || group_name_len > DB_GROUP_NAME_STR_LEN) + { + std::ostringstream temp_error; + temp_error << "A group name must be between " << DB_GROUP_NAME_MIN_LEN + << " and " << DB_GROUP_NAME_STR_LEN << " characters."; + mesg = temp_error.str(); + return false; + } - return false; - } + LLString::format_map_t args; + args["[MESSAGE]"] = mConfirmGroupCreateStr; + gViewerWindow->alertXml("GenericAlertYesCancel", args, + createGroupCallback,this); - LLGroupMgrGroupData* gdatap = gGroupMgr->getGroupData(mGroupID); + return false; + } - if (!gdatap) - { - mesg = "No group data found for group "; - mesg.append(mGroupID.asString()); - return false; - } + LLGroupMgrGroupData* gdatap = gGroupMgr->getGroupData(mGroupID); - bool can_change_ident = false; - bool can_change_member_opts = false; - can_change_ident = gAgent.hasPowerInGroup(mGroupID,GP_GROUP_CHANGE_IDENTITY); - can_change_member_opts = gAgent.hasPowerInGroup(mGroupID,GP_MEMBER_OPTIONS); + if (!gdatap) + { + mesg = "No group data found for group "; + mesg.append(mGroupID.asString()); + return false; + } + bool can_change_ident = false; + bool can_change_member_opts = false; + can_change_ident = gAgent.hasPowerInGroup(mGroupID,GP_GROUP_CHANGE_IDENTITY); + can_change_member_opts = gAgent.hasPowerInGroup(mGroupID,GP_MEMBER_OPTIONS); - if (can_change_ident) - { - if (mCtrlPublishOnWeb) gdatap->mAllowPublish = mCtrlPublishOnWeb->get(); - if (mEditCharter) gdatap->mCharter = mEditCharter->getText(); - if (mInsignia) gdatap->mInsigniaID = mInsignia->getImageAssetID(); - if (mCtrlMature) + if (can_change_ident) { - if (gAgent.mAccess > SIM_ACCESS_PG) + if (mEditCharter) gdatap->mCharter = mEditCharter->getText(); + if (mInsignia) gdatap->mInsigniaID = mInsignia->getImageAssetID(); + if (mCtrlMature) { - gdatap->mMaturePublish = mCtrlMature->get(); + if (gAgent.mAccess > SIM_ACCESS_PG) + { + gdatap->mMaturePublish = mCtrlMature->get(); + } + else + { + gdatap->mMaturePublish = FALSE; + } } - else + if (mCtrlShowInGroupList) gdatap->mShowInList = mCtrlShowInGroupList->get(); + } + + if (can_change_member_opts) + { + if (mCtrlOpenEnrollment) gdatap->mOpenEnrollment = mCtrlOpenEnrollment->get(); + if (mCtrlEnrollmentFee && mSpinEnrollmentFee) { - gdatap->mMaturePublish = FALSE; + gdatap->mMembershipFee = (mCtrlEnrollmentFee->get()) ? + (S32) mSpinEnrollmentFee->get() : 0; // Set to the used value, and reset initial value used for isdirty check mSpinEnrollmentFee->set( (F32)gdatap->mMembershipFee ); } } - if (mCtrlShowInGroupList) gdatap->mShowInList = mCtrlShowInGroupList->get(); - } - if (can_change_member_opts) - { - if (mCtrlOpenEnrollment) gdatap->mOpenEnrollment = mCtrlOpenEnrollment->get(); - if (mCtrlEnrollmentFee && mSpinEnrollmentFee) + if (can_change_ident || can_change_member_opts) { - gdatap->mMembershipFee = (mCtrlEnrollmentFee->get()) ? - (S32) mSpinEnrollmentFee->get() : 0; + gGroupMgr->sendUpdateGroupInfo(mGroupID); } } - if (can_change_ident || can_change_member_opts) - { - gGroupMgr->sendUpdateGroupInfo(mGroupID); - } + BOOL receive_notices = false; + BOOL list_in_profile = false; + if (mCtrlReceiveNotices) + receive_notices = mCtrlReceiveNotices->get(); + if (mCtrlListGroup) + list_in_profile = mCtrlListGroup->get(); - if (mCtrlReceiveNotices) gAgent.setGroupAcceptNotices(mGroupID, mCtrlReceiveNotices->get()); + gAgent.setUserGroupFlags(mGroupID, receive_notices, list_in_profile); mChanged = FALSE; - notifyObservers(); return true; } @@ -544,7 +551,7 @@ void LLPanelGroupGeneral::createGroupCallback(S32 option, void* userdata) self->mInsignia->getImageAssetID(), enrollment_fee, self->mCtrlOpenEnrollment->get(), - self->mCtrlPublishOnWeb->get(), + false, self->mCtrlMature->get()); } @@ -630,11 +637,6 @@ void LLPanelGroupGeneral::update(LLGroupChange gc) mCtrlShowInGroupList->set(gdatap->mShowInList); mCtrlShowInGroupList->setEnabled(mAllowEdit && can_change_ident); } - if (mCtrlPublishOnWeb) - { - mCtrlPublishOnWeb->set(gdatap->mAllowPublish); - mCtrlPublishOnWeb->setEnabled(mAllowEdit && can_change_ident); - } if (mCtrlMature) { mCtrlMature->set(gdatap->mMaturePublish); @@ -684,7 +686,6 @@ void LLPanelGroupGeneral::update(LLGroupChange gc) mCtrlReceiveNotices->setVisible(is_member); if (is_member) { - mCtrlReceiveNotices->set(agent_gdatap.mAcceptNotices); mCtrlReceiveNotices->setEnabled(mAllowEdit); } } @@ -825,13 +826,13 @@ void LLPanelGroupGeneral::updateChanged() mInsignia, mEditCharter, mCtrlShowInGroupList, - mCtrlPublishOnWeb, // To fix after merge: Erase this line, and uncomment the mCtrlListGroup line. -- Soft mCtrlMature, mCtrlOpenEnrollment, mCtrlEnrollmentFee, mSpinEnrollmentFee, mCtrlReceiveNotices, -// mCtrlListGroup, // To fix after merge: See above comment -- Soft + mCtrlListGroup, + mActiveTitleLabel, mComboActiveTitle }; diff --git a/linden/indra/newview/llpanelgroupgeneral.h b/linden/indra/newview/llpanelgroupgeneral.h index 07b8752..e7a27b6 100644 --- a/linden/indra/newview/llpanelgroupgeneral.h +++ b/linden/indra/newview/llpanelgroupgeneral.h @@ -2,6 +2,8 @@ * @file llpanelgroupgeneral.h * @brief General information about a group. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELGROUPGENERAL_H @@ -64,6 +67,7 @@ public: private: static void onCommitAny(LLUICtrl* ctrl, void* data); + static void onCommitUserOnly(LLUICtrl* ctrl, void* data); static void onCommitTitle(LLUICtrl* ctrl, void* data); static void onCommitEnrollment(LLUICtrl* ctrl, void* data); static void onClickJoin(void* userdata); @@ -96,12 +100,12 @@ private: // Options (include any updates in updateChanged) LLCheckBoxCtrl *mCtrlShowInGroupList; - LLCheckBoxCtrl *mCtrlPublishOnWeb; LLCheckBoxCtrl *mCtrlMature; LLCheckBoxCtrl *mCtrlOpenEnrollment; LLCheckBoxCtrl *mCtrlEnrollmentFee; LLSpinCtrl *mSpinEnrollmentFee; LLCheckBoxCtrl *mCtrlReceiveNotices; + LLCheckBoxCtrl *mCtrlListGroup; LLTextBox *mActiveTitleLabel; LLComboBox *mComboActiveTitle; diff --git a/linden/indra/newview/llpanelgroupinvite.cpp b/linden/indra/newview/llpanelgroupinvite.cpp index 4078c6d..9bab774 100644 --- a/linden/indra/newview/llpanelgroupinvite.cpp +++ b/linden/indra/newview/llpanelgroupinvite.cpp @@ -1,6 +1,8 @@ /** * @file llpanelgroupinvite.cpp * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -66,6 +69,7 @@ public: public: LLUUID mGroupID; + LLString mLoadingText; LLNameListCtrl *mInvitees; LLComboBox *mRoleNames; LLButton *mOKButton; @@ -392,14 +396,14 @@ void LLPanelGroupInvite::update() mPendingUpdate = FALSE; if (mImplementation->mGroupName) { - mImplementation->mGroupName->setText("(loading...)"); + mImplementation->mGroupName->setText(mImplementation->mLoadingText); } if ( mImplementation->mRoleNames ) { mStoreSelected = mImplementation->mRoleNames->getCurrentID(); mImplementation->mRoleNames->clear(); mImplementation->mRoleNames->removeall(); - mImplementation->mRoleNames->add("(loading...)", LLUUID::null, ADD_BOTTOM); + mImplementation->mRoleNames->add(mImplementation->mLoadingText, LLUUID::null, ADD_BOTTOM); mImplementation->mRoleNames->setCurrentByID(LLUUID::null); } @@ -470,6 +474,7 @@ BOOL LLPanelGroupInvite::postBuild() { BOOL recurse = TRUE; + mImplementation->mLoadingText = childGetText("loading"); mImplementation->mRoleNames = (LLComboBox*) getChildByName("role_name", recurse); mImplementation->mGroupName = (LLTextBox*) getChildByName("group_name_text", recurse); diff --git a/linden/indra/newview/llpanelgroupinvite.h b/linden/indra/newview/llpanelgroupinvite.h index 40e9701..e69246a 100644 --- a/linden/indra/newview/llpanelgroupinvite.h +++ b/linden/indra/newview/llpanelgroupinvite.h @@ -1,6 +1,8 @@ /** * @file llpanelgroupinvite.h * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -23,6 +25,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELGROUPINVITE_H diff --git a/linden/indra/newview/llpanelgrouplandmoney.cpp b/linden/indra/newview/llpanelgrouplandmoney.cpp index 117145e..a6ffe4f 100644 --- a/linden/indra/newview/llpanelgrouplandmoney.cpp +++ b/linden/indra/newview/llpanelgrouplandmoney.cpp @@ -2,6 +2,8 @@ * @file llpanelgrouplandmoney.cpp * @brief Panel for group land and L$. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -49,12 +52,93 @@ #include "llfloaterworldmap.h" #include "llviewermessage.h" -const char LOADING_STRING[] = "Computing..."; +//////////////////////////////////////////////////////////////////////////// + +class LLGroupMoneyTabEventHandler +{ +public: + LLGroupMoneyTabEventHandler(LLButton* earlier_button, + LLButton* later_button, + LLTextEditor* text_editor, + LLTabContainerCommon* tab_containerp, + LLPanel* panelp, + const LLString& loading_text, + const LLUUID& group_id, + S32 interval_length_days, + S32 max_interval_days); + virtual ~LLGroupMoneyTabEventHandler(); + + virtual void requestData(LLMessageSystem* msg); + virtual void processReply(LLMessageSystem* msg, void** data); + + virtual void onClickEarlier(); + virtual void onClickLater(); + virtual void onClickTab(); + + static void clickEarlierCallback(void* data); + static void clickLaterCallback(void* data); + static void clickTabCallback(void* user_data, bool from_click); + + static LLMap sInstanceIDs; + static std::map sTabsToHandlers; +protected: + class impl; + impl* mImplementationp; +}; + +class LLGroupMoneyDetailsTabEventHandler : public LLGroupMoneyTabEventHandler +{ +public: + LLGroupMoneyDetailsTabEventHandler(LLButton* earlier_buttonp, + LLButton* later_buttonp, + LLTextEditor* text_editorp, + LLTabContainerCommon* tab_containerp, + LLPanel* panelp, + const LLString& loading_text, + const LLUUID& group_id); + virtual ~LLGroupMoneyDetailsTabEventHandler(); + + virtual void requestData(LLMessageSystem* msg); + virtual void processReply(LLMessageSystem* msg, void** data); +}; + + +class LLGroupMoneySalesTabEventHandler : public LLGroupMoneyTabEventHandler +{ +public: + LLGroupMoneySalesTabEventHandler(LLButton* earlier_buttonp, + LLButton* later_buttonp, + LLTextEditor* text_editorp, + LLTabContainerCommon* tab_containerp, + LLPanel* panelp, + const LLString& loading_text, + const LLUUID& group_id); + virtual ~LLGroupMoneySalesTabEventHandler(); + + virtual void requestData(LLMessageSystem* msg); + virtual void processReply(LLMessageSystem* msg, void** data); +}; + +class LLGroupMoneyPlanningTabEventHandler : public LLGroupMoneyTabEventHandler +{ +public: + LLGroupMoneyPlanningTabEventHandler(LLTextEditor* text_editor, + LLTabContainerCommon* tab_containerp, + LLPanel* panelp, + const LLString& loading_text, + const LLUUID& group_id); + virtual ~LLGroupMoneyPlanningTabEventHandler(); + + virtual void requestData(LLMessageSystem* msg); + virtual void processReply(LLMessageSystem* msg, void** data); +}; + +//////////////////////////////////////////////////////////////////////////// class LLPanelGroupLandMoney::impl { public: - impl(const LLUUID& group_id); //constructor + impl(LLPanelGroupLandMoney& panel, const LLUUID& group_id); //constructor virtual ~impl(); void requestGroupLandInfo(); @@ -73,12 +157,10 @@ public: //member variables public: - LLTextBox *mTotalContributedLandp; - LLTextBox *mTotalLandInUsep; - LLTextBox *mLandAvailablep; + LLPanelGroupLandMoney& mPanel; + LLTextBox* mGroupOverLimitTextp; LLIconCtrl* mGroupOverLimitIconp; - LLTextBox* mYourContributionMaxTextp; LLLineEditor* mYourContributionEditorp; @@ -104,22 +186,19 @@ public: //******************************************* //** LLPanelGroupLandMoney::impl Functions ** //******************************************* -LLPanelGroupLandMoney::impl::impl(const LLUUID& group_id) +LLPanelGroupLandMoney::impl::impl(LLPanelGroupLandMoney& panel, const LLUUID& group_id) + : mPanel(panel), + mGroupID(group_id) { - mGroupID = group_id; mTransID = LLUUID::null; mBeenActivated = false; mNeedsSendGroupLandRequest = true; mNeedsApply = false; - mTotalLandInUsep = NULL; - mTotalContributedLandp = NULL; - mLandAvailablep = NULL; mYourContributionEditorp = NULL; mMapButtonp = NULL; mGroupParcelsp = NULL; - mYourContributionMaxTextp = NULL; mGroupOverLimitTextp = NULL; mGroupOverLimitIconp = NULL; @@ -227,9 +306,7 @@ int LLPanelGroupLandMoney::impl::getStoredContribution() // Fills in the text field with the contribution, contrib void LLPanelGroupLandMoney::impl::setYourContributionTextField(int contrib) { - char buffer[MAX_STRING]; /* Flawfinder: ignore*/ - buffer[0] = '\0'; - snprintf(buffer, sizeof(buffer), "%d", contrib); /* Flawfinder: ignore*/ + LLString buffer = llformat("%d", contrib); if ( mYourContributionEditorp ) { @@ -240,14 +317,7 @@ void LLPanelGroupLandMoney::impl::setYourContributionTextField(int contrib) void LLPanelGroupLandMoney::impl::setYourMaxContributionTextBox(int max) { - char buffer[MAX_STRING]; /*Flawfinder: ignore*/ - buffer[0] = '\0'; - - snprintf(buffer, sizeof(buffer), "(%d max)", max); /* Flawfinder: ignore */ - if ( mYourContributionMaxTextp ) - { - mYourContributionMaxTextp->setText(buffer); - } + mPanel.childSetTextArg("your_contribution_max_value", "[AMOUNT]", llformat("%d", max)); } //static @@ -306,19 +376,18 @@ void LLPanelGroupLandMoney::impl::processGroupLand(LLMessageSystem* msg) { // special block which has total contribution ++first_block; + S32 total_contribution; msg->getS32("QueryData", "ActualArea", total_contribution, 0); - char buffer[MAX_STRING]; /*Flawfinder: ignore*/ - snprintf(buffer, sizeof(buffer), "%d sq. meters", total_contribution); /* Flawfinder: ignore */ - mTotalContributedLandp->setText(buffer); + mPanel.childSetTextArg("total_contributed_land_value", "[AREA]", llformat("%d", total_contribution)); + S32 committed; msg->getS32("QueryData", "BillableArea", committed, 0); - snprintf(buffer, sizeof(buffer), "%d sq. meters", committed); /* Flawfinder: ignore */ - mTotalLandInUsep->setText(buffer); + mPanel.childSetTextArg("total_land_in_use_value", "[AREA]", llformat("%d", committed)); + S32 available = total_contribution - committed; - snprintf(buffer, sizeof(buffer), "%d sq. meters", available); /* Flawfinder: ignore */ - mLandAvailablep->setText(buffer); - buffer[0] = '\0'; + mPanel.childSetTextArg("land_available_value", "[AREA]", llformat("%d", available)); + if ( mGroupOverLimitTextp && mGroupOverLimitIconp ) { mGroupOverLimitIconp->setVisible(available < 0); @@ -413,7 +482,7 @@ LLPanelGroupLandMoney::LLPanelGroupLandMoney(const std::string& name, const LLUUID& group_id) : LLPanelGroupTab(name, group_id) { - mImplementationp = new impl(group_id); + mImplementationp = new impl(*this, group_id); //problem what if someone has both the group floater open and the finder //open to the same group? Some maps that map group ids to panels @@ -535,18 +604,10 @@ BOOL LLPanelGroupLandMoney::postBuild() bool can_view = gAgent.isInGroup(mGroupID); - mImplementationp->mTotalLandInUsep = - (LLTextBox*) getChildByName("total_land_in_use_value"); - mImplementationp->mTotalContributedLandp = - (LLTextBox*) getChildByName("total_contributed_land_value"); - mImplementationp->mLandAvailablep = - (LLTextBox*) getChildByName("land_available_value"); mImplementationp->mGroupOverLimitIconp = (LLIconCtrl*) getChildByName("group_over_limit_icon"); mImplementationp->mGroupOverLimitTextp = (LLTextBox*) getChildByName("group_over_limit_text"); - mImplementationp->mYourContributionMaxTextp = - (LLTextBox*) getChildByName("your_contribution_max_value"); mImplementationp->mYourContributionEditorp = (LLLineEditor*) getChildByName("your_contribution_line_editor"); @@ -633,7 +694,8 @@ BOOL LLPanelGroupLandMoney::postBuild() } } - + LLString loading_text = childGetText("loading_txt"); + //pull out the widgets for the L$ details tab earlierp = (LLButton*) getChildByName("earlier_details_button", true); laterp = (LLButton*) getChildByName("later_details_button", true); @@ -652,6 +714,7 @@ BOOL LLPanelGroupLandMoney::postBuild() textp, tabcp, panelp, + loading_text, mGroupID); } @@ -668,6 +731,7 @@ BOOL LLPanelGroupLandMoney::postBuild() new LLGroupMoneyPlanningTabEventHandler(textp, tabcp, panelp, + loading_text, mGroupID); } @@ -689,6 +753,7 @@ BOOL LLPanelGroupLandMoney::postBuild() textp, tabcp, panelp, + loading_text, mGroupID); } @@ -726,7 +791,8 @@ public: impl(LLButton* earlier_buttonp, LLButton* later_buttonp, LLTextEditor* text_editorp, - LLPanel* panelp, + LLPanel* tabpanelp, + const LLString& loading_text, const LLUUID& group_id, S32 interval_length_days, S32 max_interval_days); @@ -742,7 +808,7 @@ public: LLUUID mGroupID; LLUUID mPanelID; - LLPanel* mPanelp; + LLPanel* mTabPanelp; int mIntervalLength; int mMaxInterval; @@ -751,12 +817,15 @@ public: LLTextEditor* mTextEditorp; LLButton* mEarlierButtonp; LLButton* mLaterButtonp; + + LLString mLoadingText; }; LLGroupMoneyTabEventHandler::impl::impl(LLButton* earlier_buttonp, LLButton* later_buttonp, LLTextEditor* text_editorp, - LLPanel* panelp, + LLPanel* tabpanelp, + const LLString& loading_text, const LLUUID& group_id, S32 interval_length_days, S32 max_interval_days) @@ -771,7 +840,9 @@ LLGroupMoneyTabEventHandler::impl::impl(LLButton* earlier_buttonp, mTextEditorp = text_editorp; mEarlierButtonp = earlier_buttonp; mLaterButtonp = later_buttonp; - mPanelp = panelp; + mTabPanelp = tabpanelp; + + mLoadingText = loading_text; } LLGroupMoneyTabEventHandler::impl::~impl() @@ -803,6 +874,7 @@ void LLGroupMoneyTabEventHandler::impl::updateButtons() //******************************************* //** LLGroupMoneyTabEventHandler Functions ** //******************************************* + LLMap LLGroupMoneyTabEventHandler::sInstanceIDs; std::map LLGroupMoneyTabEventHandler::sTabsToHandlers; @@ -811,6 +883,7 @@ LLGroupMoneyTabEventHandler::LLGroupMoneyTabEventHandler(LLButton* earlier_butto LLTextEditor* text_editorp, LLTabContainerCommon* tab_containerp, LLPanel* panelp, + const LLString& loading_text, const LLUUID& group_id, S32 interval_length_days, S32 max_interval_days) @@ -819,28 +892,26 @@ LLGroupMoneyTabEventHandler::LLGroupMoneyTabEventHandler(LLButton* earlier_butto later_buttonp, text_editorp, panelp, + loading_text, group_id, interval_length_days, max_interval_days); if ( earlier_buttonp ) { - earlier_buttonp->setClickedCallback(LLGroupMoneyTabEventHandler::clickEarlierCallback, - this); + earlier_buttonp->setClickedCallback(clickEarlierCallback, this); } if ( later_buttonp ) { - later_buttonp->setClickedCallback(LLGroupMoneyTabEventHandler::clickLaterCallback, - this); + later_buttonp->setClickedCallback(clickLaterCallback, this); } mImplementationp->updateButtons(); if ( tab_containerp && panelp ) { - tab_containerp->setTabChangeCallback(panelp, - LLGroupMoneyTabEventHandler::clickTabCallback); + tab_containerp->setTabChangeCallback(panelp, clickTabCallback); tab_containerp->setTabUserData(panelp, this); } @@ -851,7 +922,7 @@ LLGroupMoneyTabEventHandler::LLGroupMoneyTabEventHandler(LLButton* earlier_butto LLGroupMoneyTabEventHandler::~LLGroupMoneyTabEventHandler() { sInstanceIDs.removeData(mImplementationp->mPanelID); - sTabsToHandlers.erase(mImplementationp->mPanelp); + sTabsToHandlers.erase(mImplementationp->mTabPanelp); delete mImplementationp; } @@ -876,7 +947,7 @@ void LLGroupMoneyTabEventHandler::onClickEarlier() { if ( mImplementationp->mTextEditorp) { - mImplementationp->mTextEditorp->setText(LOADING_STRING); + mImplementationp->mTextEditorp->setText(mImplementationp->mLoadingText); } mImplementationp->mCurrentInterval++; @@ -889,7 +960,7 @@ void LLGroupMoneyTabEventHandler::onClickLater() { if ( mImplementationp->mTextEditorp ) { - mImplementationp->mTextEditorp->setText(LOADING_STRING); + mImplementationp->mTextEditorp->setText(mImplementationp->mLoadingText); } mImplementationp->mCurrentInterval--; @@ -929,12 +1000,14 @@ LLGroupMoneyDetailsTabEventHandler::LLGroupMoneyDetailsTabEventHandler(LLButton* LLTextEditor* text_editorp, LLTabContainerCommon* tab_containerp, LLPanel* panelp, + const LLString& loading_text, const LLUUID& group_id) : LLGroupMoneyTabEventHandler(earlier_buttonp, later_buttonp, text_editorp, tab_containerp, panelp, + loading_text, group_id, SUMMARY_INTERVAL, SUMMARY_MAX) @@ -961,7 +1034,7 @@ void LLGroupMoneyDetailsTabEventHandler::requestData(LLMessageSystem* msg) if ( mImplementationp->mTextEditorp ) { - mImplementationp->mTextEditorp->setText(LOADING_STRING); + mImplementationp->mTextEditorp->setText(mImplementationp->mLoadingText); } LLGroupMoneyTabEventHandler::requestData(msg); @@ -1035,8 +1108,8 @@ void LLGroupMoneyDetailsTabEventHandler::processReply(LLMessageSystem* msg, } //static -void LLGroupMoneyDetailsTabEventHandler::processGroupAccountDetailsReply(LLMessageSystem* msg, - void** data) +void LLPanelGroupLandMoney::processGroupAccountDetailsReply(LLMessageSystem* msg, + void** data) { LLUUID agent_id; msg->getUUIDFast(_PREHASH_AgentData, _PREHASH_AgentID, agent_id ); @@ -1068,12 +1141,14 @@ LLGroupMoneySalesTabEventHandler::LLGroupMoneySalesTabEventHandler(LLButton* ear LLTextEditor* text_editorp, LLTabContainerCommon* tab_containerp, LLPanel* panelp, + const LLString& loading_text, const LLUUID& group_id) : LLGroupMoneyTabEventHandler(earlier_buttonp, later_buttonp, text_editorp, tab_containerp, panelp, + loading_text, group_id, SUMMARY_INTERVAL, SUMMARY_MAX) @@ -1100,7 +1175,7 @@ void LLGroupMoneySalesTabEventHandler::requestData(LLMessageSystem* msg) if ( mImplementationp->mTextEditorp ) { - mImplementationp->mTextEditorp->setText(LOADING_STRING); + mImplementationp->mTextEditorp->setText(mImplementationp->mLoadingText); } LLGroupMoneyTabEventHandler::requestData(msg); @@ -1138,7 +1213,7 @@ void LLGroupMoneySalesTabEventHandler::processReply(LLMessageSystem* msg, // If this is the first packet, clear the text, don't append. // Start with the date. - if (text == LOADING_STRING) + if (text == mImplementationp->mLoadingText) { text.clear(); @@ -1210,8 +1285,8 @@ void LLGroupMoneySalesTabEventHandler::processReply(LLMessageSystem* msg, } //static -void LLGroupMoneySalesTabEventHandler::processGroupAccountTransactionsReply(LLMessageSystem* msg, - void** data) +void LLPanelGroupLandMoney::processGroupAccountTransactionsReply(LLMessageSystem* msg, + void** data) { LLUUID agent_id; msg->getUUIDFast(_PREHASH_AgentData, _PREHASH_AgentID, agent_id ); @@ -1244,12 +1319,14 @@ void LLGroupMoneySalesTabEventHandler::processGroupAccountTransactionsReply(LLMe LLGroupMoneyPlanningTabEventHandler::LLGroupMoneyPlanningTabEventHandler(LLTextEditor* text_editorp, LLTabContainerCommon* tab_containerp, LLPanel* panelp, + const LLString& loading_text, const LLUUID& group_id) : LLGroupMoneyTabEventHandler(NULL, NULL, text_editorp, tab_containerp, panelp, + loading_text, group_id, SUMMARY_INTERVAL, SUMMARY_MAX) @@ -1276,7 +1353,7 @@ void LLGroupMoneyPlanningTabEventHandler::requestData(LLMessageSystem* msg) if ( mImplementationp->mTextEditorp ) { - mImplementationp->mTextEditorp->setText(LOADING_STRING); + mImplementationp->mTextEditorp->setText(mImplementationp->mLoadingText); } LLGroupMoneyTabEventHandler::requestData(msg); @@ -1379,8 +1456,8 @@ void LLGroupMoneyPlanningTabEventHandler::processReply(LLMessageSystem* msg, } //static -void LLGroupMoneyPlanningTabEventHandler::processGroupAccountSummaryReply(LLMessageSystem* msg, - void** data) +void LLPanelGroupLandMoney::processGroupAccountSummaryReply(LLMessageSystem* msg, + void** data) { LLUUID agent_id; msg->getUUIDFast(_PREHASH_AgentData, _PREHASH_AgentID, agent_id ); diff --git a/linden/indra/newview/llpanelgrouplandmoney.h b/linden/indra/newview/llpanelgrouplandmoney.h index 8ac8bc7..83126f9 100644 --- a/linden/indra/newview/llpanelgrouplandmoney.h +++ b/linden/indra/newview/llpanelgrouplandmoney.h @@ -2,6 +2,8 @@ * @file llpanelgrouplandmoney.h * @brief Panel for group land and L$. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_PANEL_GROUP_LAND_MONEY_H @@ -56,92 +59,14 @@ public: static void processPlacesReply(LLMessageSystem* msg, void**); static LLMap sGroupIDs; -protected: - class impl; - impl* mImplementationp; -}; - -class LLGroupMoneyTabEventHandler -{ -public: - LLGroupMoneyTabEventHandler(LLButton* earlier_button, - LLButton* later_button, - LLTextEditor* text_editor, - LLTabContainerCommon* tab_containerp, - LLPanel* panelp, - const LLUUID& group_id, - S32 interval_length_days, - S32 max_interval_days); - virtual ~LLGroupMoneyTabEventHandler(); - virtual void requestData(LLMessageSystem* msg); - virtual void processReply(LLMessageSystem* msg, void** data); - - virtual void onClickEarlier(); - virtual void onClickLater(); - virtual void onClickTab(); - - static void clickEarlierCallback(void* data); - static void clickLaterCallback(void* data); - static void clickTabCallback(void* user_data, bool from_click); - - static LLMap sInstanceIDs; - static std::map sTabsToHandlers; + static void processGroupAccountDetailsReply(LLMessageSystem* msg, void** data); + static void processGroupAccountTransactionsReply(LLMessageSystem* msg, void** data); + static void processGroupAccountSummaryReply(LLMessageSystem* msg, void** data); + protected: class impl; impl* mImplementationp; }; -class LLGroupMoneyDetailsTabEventHandler : public LLGroupMoneyTabEventHandler -{ -public: - LLGroupMoneyDetailsTabEventHandler(LLButton* earlier_buttonp, - LLButton* later_buttonp, - LLTextEditor* text_editorp, - LLTabContainerCommon* tab_containerp, - LLPanel* panelp, - const LLUUID& group_id); - virtual ~LLGroupMoneyDetailsTabEventHandler(); - - virtual void requestData(LLMessageSystem* msg); - virtual void processReply(LLMessageSystem* msg, void** data); - - static void processGroupAccountDetailsReply(LLMessageSystem* msg, - void** data); -}; - -class LLGroupMoneySalesTabEventHandler : public LLGroupMoneyTabEventHandler -{ -public: - LLGroupMoneySalesTabEventHandler(LLButton* earlier_buttonp, - LLButton* later_buttonp, - LLTextEditor* text_editorp, - LLTabContainerCommon* tab_containerp, - LLPanel* panelp, - const LLUUID& group_id); - virtual ~LLGroupMoneySalesTabEventHandler(); - - virtual void requestData(LLMessageSystem* msg); - virtual void processReply(LLMessageSystem* msg, void** data); - - static void processGroupAccountTransactionsReply(LLMessageSystem* msg, - void** data); -}; - -class LLGroupMoneyPlanningTabEventHandler : public LLGroupMoneyTabEventHandler -{ -public: - LLGroupMoneyPlanningTabEventHandler(LLTextEditor* text_editor, - LLTabContainerCommon* tab_containerp, - LLPanel* panelp, - const LLUUID& group_id); - virtual ~LLGroupMoneyPlanningTabEventHandler(); - - virtual void requestData(LLMessageSystem* msg); - virtual void processReply(LLMessageSystem* msg, void** data); - - static void processGroupAccountSummaryReply(LLMessageSystem* msg, - void** data); -}; - #endif // LL_PANEL_GROUP_LAND_MONEY_H diff --git a/linden/indra/newview/llpanelgroupnotices.cpp b/linden/indra/newview/llpanelgroupnotices.cpp index e335929..c7c7912 100644 --- a/linden/indra/newview/llpanelgroupnotices.cpp +++ b/linden/indra/newview/llpanelgroupnotices.cpp @@ -2,6 +2,8 @@ * @file llpanelgroupnotices.cpp * @brief A panel to display group notices. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -542,8 +545,8 @@ void LLPanelGroupNotices::showNotice(const char* subject, { arrangeNoticeView(VIEW_PAST_NOTICE); - if(mViewSubject) mViewSubject->setText(subject); - if(mViewMessage) mViewMessage->setText(message); + if(mViewSubject) mViewSubject->setText(LLString(subject)); + if(mViewMessage) mViewMessage->setText(LLString(message)); if (mInventoryOffer) { diff --git a/linden/indra/newview/llpanelgroupnotices.h b/linden/indra/newview/llpanelgroupnotices.h index ba520e0..aaac23f 100644 --- a/linden/indra/newview/llpanelgroupnotices.h +++ b/linden/indra/newview/llpanelgroupnotices.h @@ -2,6 +2,8 @@ * @file llpanelgroupnotices.h * @brief A panel to display group notices. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELGROUPNOTICES_H diff --git a/linden/indra/newview/llpanelgrouproles.cpp b/linden/indra/newview/llpanelgrouproles.cpp index e6944d9..ce824cb 100644 --- a/linden/indra/newview/llpanelgrouproles.cpp +++ b/linden/indra/newview/llpanelgrouproles.cpp @@ -2,6 +2,8 @@ * @file llpanelgrouproles.cpp * @brief Panel for roles information about a particular group. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llpanelgrouproles.h b/linden/indra/newview/llpanelgrouproles.h index c3934c6..b0b635e 100644 --- a/linden/indra/newview/llpanelgrouproles.h +++ b/linden/indra/newview/llpanelgrouproles.h @@ -2,6 +2,8 @@ * @file llpanelgrouproles.h * @brief Panel for roles information about a particular group. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELGROUPROLES_H diff --git a/linden/indra/newview/llpanelgroupvoting.cpp b/linden/indra/newview/llpanelgroupvoting.cpp index e21af7a..b74bf9c 100644 --- a/linden/indra/newview/llpanelgroupvoting.cpp +++ b/linden/indra/newview/llpanelgroupvoting.cpp @@ -2,6 +2,8 @@ * @file llpanelgroupvoting.cpp * @brief LLPanelGroupVoting class definition. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -48,7 +51,7 @@ class LLPanelGroupVoting::impl { public: - impl(const LLUUID& group_id); + impl(LLPanelGroupVoting& panel, const LLUUID& group_id); ~impl(); static void onClickCreateProposal(void* userdata); @@ -96,7 +99,8 @@ public: LLUUID mGroupID; LLUUID mProposalID; - LLTextBox *mQuorumText; + LLPanelGroupVoting& mPanel; + LLSpinCtrl *mQuorum; LLTextBox *mQuorumLbl; LLSpinCtrl *mDuration; @@ -104,9 +108,6 @@ public: LLTextBox *mDurationText; LLRadioGroup *mMajority; LLTextBox *mMajorityLbl; - LLTextBox *mInstructions; - LLTextBox *mProposalHeader; - LLTextBox *mProposalLbl; LLTextBox *mStartLbl; LLTextBox *mEndLbl; LLTextBox *mStartDate; @@ -131,11 +132,6 @@ public: LLButton *mBtnViewHistoryList; LLButton *mBtnViewHistoryItem; - std::string mViewProposalHeaderText; - std::string mCreateProposalHeaderText; - std::string mVoteProposalHeaderText; - std::string mEmptyProposalText; - int mNumGroupMembers; std::vector mActiveReceived; @@ -154,9 +150,10 @@ public: //** LLPanelGroupVoting::impl Functions ** //**************************************** -LLPanelGroupVoting::impl::impl(const LLUUID& group_id) +LLPanelGroupVoting::impl::impl(LLPanelGroupVoting& panel, const LLUUID& group_id) + : mPanel(panel), + mGroupID(group_id) { - mGroupID = group_id; mNumGroupMembers = 0; @@ -185,7 +182,6 @@ LLPanelGroupVoting::impl::impl(const LLUUID& group_id) //will then only be working for the last panel for a given group id :( sGroupIDs[group_id] = this; - mQuorumText = NULL; mQuorum = NULL; mQuorumLbl = NULL; mDuration = NULL; @@ -193,9 +189,6 @@ LLPanelGroupVoting::impl::impl(const LLUUID& group_id) mDurationText = NULL; mMajority = NULL; mMajorityLbl = NULL; - mInstructions = NULL; - mProposalHeader = NULL; - mProposalLbl = NULL; mStartLbl = NULL; mEndLbl = NULL; mStartDate = NULL; @@ -239,10 +232,10 @@ void LLPanelGroupVoting::impl::setEnableListProposals() return; - mProposalHeader->setText(mViewProposalHeaderText); - mInstructions->setText("Double Click on the proposal you would like to vote on or press\n" - "Create Proposal to create a new proposal."); - mProposalLbl->setText("Proposal Voting Ends Voted?"); + mPanel.childSetText("proposal_header", mPanel.childGetText("proposals_header_view_txt")); + mPanel.childSetText("proposal_instructions", mPanel.childGetText("proposals_header_view_inst")); + mPanel.childSetVisible("proposal_lbl", FALSE); + mPanel.childSetVisible("proposal_voting_lbl", TRUE); mProposals->setVisible(TRUE); mProposals->setBgSelectedColor(gColors.getColor("ScrollSelectedBGColor")); mProposalText->setVisible(FALSE); @@ -266,7 +259,7 @@ void LLPanelGroupVoting::impl::setEnableListProposals() mQuorumLbl->setVisible(FALSE); mQuorum->setEnabled(FALSE); mQuorum->setVisible(FALSE); - mQuorumText->setVisible(FALSE); + mPanel.childSetVisible("quorum_text", FALSE); mDurationLbl->setVisible(FALSE); mDuration->setEnabled(FALSE); @@ -301,16 +294,72 @@ void LLPanelGroupVoting::impl::setEnableVoteProposal() std::string vote_cast; mProposalID = item->getUUID(); + // col 0: index id - mProposalText->setText(item->getColumn(1)->getText()); //proposal text - mEndDate->setText(item->getColumn(2)->getText()); //end date + LLScrollListCell * proposal_cell = item->getColumn(1); + if ( proposal_cell ) + { + mProposalText->setText(proposal_cell->getText()); //proposal text + } + else + { // Something's wrong... should have some text + mProposalText->setText(LLString()); + } + + proposal_cell = item->getColumn(2); + if (proposal_cell) + { + mEndDate->setText(proposal_cell->getText()); //end date + } + else + { // Something's wrong... should have some text + mEndDate->setText(LLString()); + } + // col 3: Vote Type - already_voted = item->getColumn(4)->getText(); //already voted - mStartDate->setText(item->getColumn(5)->getText()); //start date - vote_cast = item->getColumn(6)->getText(); // Vote Cast - // col 7: Vote Initiator - mQuorum->set((F32)atoi(item->getColumn(8)->getText().c_str())); //quorum - F32 majority = (F32)atof(item->getColumn(9)->getText().c_str()); //majority + proposal_cell = item->getColumn(3); + if (proposal_cell) + { + already_voted = proposal_cell->getText(); //already voted + } + else + { // Something's wrong... should have some text + already_voted = ""; + } + + proposal_cell = item->getColumn(5); + if (proposal_cell) + { + mStartDate->setText(proposal_cell->getText()); //start date + } + else + { // Something's wrong... should have some text + mStartDate->setText(LLString()); + } + + proposal_cell = item->getColumn(6); + if (proposal_cell) + { + vote_cast = proposal_cell->getText(); // Vote Cast + } + + // col 8: Vote Initiator + proposal_cell = item->getColumn(8); + if (proposal_cell) + { + mQuorum->set((F32)atoi(proposal_cell->getText().c_str())); //quorum + } + else + { + mQuorum->set(0); + } + + F32 majority = 0.0f; + proposal_cell = item->getColumn(9); + if (proposal_cell) + { + majority = (F32)atof(proposal_cell->getText().c_str()); //majority + } if(majority == 0.0f) { // Select the Simple Majority @@ -329,9 +378,9 @@ void LLPanelGroupVoting::impl::setEnableVoteProposal() if (already_voted == "Yes") { - char message[MAX_STRING]; /*Flawfinder: ignore*/ - snprintf(message, MAX_STRING, "You have voted: %s ", vote_cast.c_str()); /* Flawfinder: ignore */ - mInstructions->setText(message); + LLUIString votestr = mPanel.childGetText("proposals_header_voted_inst"); + votestr.setArg("[VOTE]", vote_cast); + mPanel.childSetText("proposal_instructions", votestr.getString()); mBtnYes->setEnabled(FALSE); mBtnNo->setEnabled(FALSE); @@ -339,16 +388,16 @@ void LLPanelGroupVoting::impl::setEnableVoteProposal() } else { - mInstructions->setText("Press the Yes or No button to vote on the proposal, \n" - "or choose to Abstain voting on this proposal."); + mPanel.childSetText("proposal_instructions", mPanel.childGetText("proposals_header_vote_inst")); mBtnYes->setEnabled(TRUE); mBtnNo->setEnabled(TRUE); mBtnAbstain->setEnabled(TRUE); } - mProposalHeader->setText(mVoteProposalHeaderText); - mProposalLbl->setText("Proposal Description"); + mPanel.childSetText("proposal_header", mPanel.childGetText("proposals_header_vote_txt")); + mPanel.childSetVisible("proposal_lbl", TRUE); + mPanel.childSetVisible("proposal_voting_lbl", FALSE); mProposals->setVisible(FALSE); mProposalText->setEnabled(FALSE); mProposalText->setVisible(TRUE); @@ -371,7 +420,7 @@ void LLPanelGroupVoting::impl::setEnableVoteProposal() mQuorumLbl->setVisible(TRUE); mQuorum->setEnabled(FALSE); mQuorum->setVisible(TRUE); - mQuorumText->setVisible(TRUE); + mPanel.childSetVisible("quorum_text", TRUE); mDurationLbl->setVisible(FALSE); mDuration->setEnabled(FALSE); @@ -393,13 +442,14 @@ void LLPanelGroupVoting::impl::setEnableCreateProposal() if ( !gAgent.hasPowerInGroup(mGroupID, GP_PROPOSAL_START) ) return; - mProposalHeader->setText(mCreateProposalHeaderText); - mInstructions->setText("Type the Proposal Description for the new proposal. You can change the\nQuorum, Duration and Majority required to pass the proposal."); - mProposalLbl->setText("Proposal Description"); + mPanel.childSetText("proposal_header", mPanel.childGetText("proposals_header_create_txt")); + mPanel.childSetText("proposal_instructions", mPanel.childGetText("proposals_header_create_inst")); + mPanel.childSetVisible("proposal_lbl", TRUE); + mPanel.childSetVisible("proposal_voting_lbl", FALSE); mProposals->setVisible(FALSE); mProposalText->setEnabled(TRUE); mProposalText->setVisible(TRUE); - mProposalText->setText(""); + mProposalText->setText(LLString::null); mBtnYes->setEnabled(FALSE); mBtnYes->setVisible(FALSE); mBtnNo->setEnabled(FALSE); @@ -422,7 +472,7 @@ void LLPanelGroupVoting::impl::setEnableCreateProposal() mQuorumLbl->setVisible(TRUE); mQuorum->setEnabled(TRUE); mQuorum->setVisible(TRUE); - mQuorumText->setVisible(TRUE); + mPanel.childSetVisible("quorum_text", TRUE); mDurationLbl->setVisible(TRUE); mDuration->setEnabled(TRUE); @@ -488,8 +538,14 @@ void LLPanelGroupVoting::impl::setEnableHistoryItem() LLScrollListItem *item = mVotesHistory->getFirstSelected(); // Get full text, not stripped version. const LLScrollListCell *cell = item->getColumn(5); - mVoteHistoryText->setText(cell->getText()); - + if (cell) + { + mVoteHistoryText->setText(cell->getText()); + } + else + { // Something's wrong... + mVoteHistoryText->setText(LLString()); + } mVotesHistoryLbl->setVisible(FALSE); mVotesHistory->setVisible(FALSE); @@ -635,15 +691,7 @@ void LLPanelGroupVoting::impl::sendGroupVoteHistoryRequest(const LLUUID& group_i void LLPanelGroupVoting::impl::updateQuorumText() { - if ( mQuorumText ) - { - //update the quorum count - char quorum_text[MAX_STRING]; /*Flawfinder: ignore*/ - snprintf(quorum_text, MAX_STRING, /* Flawfinder: ignore */ - " out of %d members must vote", - mNumGroupMembers); - mQuorumText->setText(quorum_text); - } + mPanel.childSetTextArg("quorum_text", "[MEMBERS]", llformat("%d", mNumGroupMembers)); } void LLPanelGroupVoting::impl::addPendingActiveScrollListItem(unsigned int current, @@ -1052,9 +1100,9 @@ void LLPanelGroupVoting::impl::onClickYes(void *userdata) { LLPanelGroupVoting::impl* self = (LLPanelGroupVoting::impl*)userdata; - if ( self && self->mInstructions ) + if ( self ) { - self->mInstructions->setText("Submitting Yes to proposal..."); + self->mPanel.childSetText("proposal_instructions", self->mPanel.childGetText("proposals_submit_yes_txt")); self->sendGroupProposalBallot("Yes"); //refresh the proposals now that we've hit yes @@ -1069,9 +1117,9 @@ void LLPanelGroupVoting::impl::onClickNo(void *userdata) { LLPanelGroupVoting::impl* self = (LLPanelGroupVoting::impl*)userdata; - if ( self && self->mInstructions ) + if ( self ) { - self->mInstructions->setText("Submitting No to proposal..."); + self->mPanel.childSetText("proposal_instructions", self->mPanel.childGetText("proposals_submit_no_txt")); self->sendGroupProposalBallot("No"); //refresh the proposals now that we've hit no @@ -1086,9 +1134,9 @@ void LLPanelGroupVoting::impl::onClickAbstain(void *userdata) { impl* self = (LLPanelGroupVoting::impl*) userdata; - if ( self && self->mInstructions ) + if ( self ) { - self->mInstructions->setText("Submitting Abstention to proposal..."); + self->mPanel.childSetText("proposal_instructions", self->mPanel.childGetText("proposals_submit_abstain_txt")); self->sendGroupProposalBallot("Abstain"); //refresh the proposals now that we've hit abstain @@ -1104,7 +1152,7 @@ void LLPanelGroupVoting::impl::onClickSubmitProposal(void *userdata) gFocusMgr.setKeyboardFocus(NULL, NULL); impl* self = (impl*)userdata; - if ( self && self->mInstructions && self->mProposalText ) + if ( self && self->mProposalText ) { //check to see if the proposal has any text for some form of //"validation" @@ -1112,12 +1160,12 @@ void LLPanelGroupVoting::impl::onClickSubmitProposal(void *userdata) { //throw up an error dialog LLString::format_map_t args; - args["[MESSAGE]"] = self->mEmptyProposalText; + args["[MESSAGE]"] = self->mPanel.childGetText("empty_proposal_txt"); gViewerWindow->alertXml("GenericAlert", args); return; } - self->mInstructions->setText("Submitting new Proposal..."); + self->mPanel.childSetText("proposal_instructions", self->mPanel.childGetText("proposals_submit_new_txt")); self->sendStartGroupProposal(); //refresh the proposals now that we've submitted a new one @@ -1152,7 +1200,9 @@ void LLPanelGroupVoting::impl::onClickViewProposalItem(void *userdata) if ( self && self->mProposals ) { - if (self->mProposals->getFirstSelected() != NULL) + LLScrollListItem * proposal = self->mProposals->getFirstSelected(); + // Check if it has anything in column 2. If not, assume it's the "There are currently no active proposals" text + if (proposal && proposal->getColumn(2)) { self->setEnableVoteProposal(); } @@ -1188,13 +1238,18 @@ void LLPanelGroupVoting::impl::onClickViewHistoryItem(void *userdata) { impl* self = (impl*)userdata; - if (self->mVotesHistory->getFirstSelected() != NULL) - { - self->setEnableHistoryItem(); - } - else + if ( self && self->mVotesHistory ) { - gViewerWindow->alertXml("SelectHistoryItemToView"); + LLScrollListItem * historic = self->mVotesHistory->getFirstSelected(); + // Check if it has anything in column 2. If not, assume it's the "There are currently no active proposals" text + if (historic && historic->getColumn(2)) + { + self->setEnableHistoryItem(); + } + else + { + gViewerWindow->alertXml("SelectHistoryItemToView"); + } } } @@ -1221,7 +1276,7 @@ LLPanelGroupVoting::LLPanelGroupVoting(const std::string& name, const LLUUID& group_id) : LLPanelGroupTab(name, group_id) { - mImpl = new impl(group_id); + mImpl = new impl(*this, group_id); } LLPanelGroupVoting::~LLPanelGroupVoting() @@ -1239,7 +1294,6 @@ BOOL LLPanelGroupVoting::postBuild() { bool recurse = true; - mImpl->mQuorumText = (LLTextBox*) getChildByName("quorum_text", recurse); mImpl->mDurationText = (LLTextBox*) getChildByName("duration_text", recurse); mImpl->mQuorum = (LLSpinCtrl*) getChildByName("quorum", recurse); @@ -1248,12 +1302,7 @@ BOOL LLPanelGroupVoting::postBuild() mImpl->mDurationLbl = (LLTextBox*) getChildByName("duration_lbl", recurse); mImpl->mMajority = (LLRadioGroup*) getChildByName("majority", recurse); mImpl->mMajorityLbl = (LLTextBox*) getChildByName("majority_lbl", recurse); - mImpl->mInstructions = (LLTextBox*) getChildByName("proposal_instructions", - recurse); - mImpl->mProposalHeader = (LLTextBox*) getChildByName("proposal_header", - recurse); - mImpl->mProposalLbl = (LLTextBox*) getChildByName("proposal_lbl", recurse); mImpl->mStartLbl = (LLTextBox*) getChildByName("start_lbl", recurse); mImpl->mEndLbl = (LLTextBox*) getChildByName("end_lbl", recurse); mImpl->mStartDate = (LLTextBox*) getChildByName("start_date", recurse); @@ -1294,48 +1343,15 @@ BOOL LLPanelGroupVoting::postBuild() mImpl->mBtnViewHistoryItem = (LLButton*)getChildByName("btn_view_history_item", recurse); - LLTextBox *txt = (LLTextBox*) getChildByName("proposals_header_view_txt", - recurse); - if (txt) - { - mImpl->mViewProposalHeaderText = txt->getText(); - removeChild(txt, TRUE); - } - - txt = (LLTextBox*) getChildByName("proposals_header_create_txt", recurse); - if (txt) - { - mImpl->mCreateProposalHeaderText = txt->getText(); - removeChild(txt, TRUE); - } - - txt = (LLTextBox*) getChildByName("proposals_header_vote_txt", recurse); - if (txt) - { - mImpl->mVoteProposalHeaderText = txt->getText(); - removeChild(txt, TRUE); - } - - txt = (LLTextBox*) getChildByName("empty_proposal_txt", recurse); - if (txt) - { - mImpl->mEmptyProposalText = txt->getText(); - removeChild(txt, TRUE); - } - mImpl->updateQuorumText(); - bool success = (mImpl->mQuorumText && - mImpl->mDurationText && + bool success = (mImpl->mDurationText && mImpl->mQuorum && mImpl->mQuorumLbl && mImpl->mDuration && mImpl->mDurationLbl && mImpl->mMajority && mImpl->mMajorityLbl && - mImpl->mInstructions && - mImpl->mProposalHeader && - mImpl->mProposalLbl && mImpl->mStartLbl && mImpl->mEndLbl && mImpl->mStartDate && @@ -1442,3 +1458,4 @@ void LLPanelGroupVoting::update(LLGroupChange gc) mImpl->sendGroupVoteHistoryRequest(mGroupID); } + diff --git a/linden/indra/newview/llpanelgroupvoting.h b/linden/indra/newview/llpanelgroupvoting.h index 38f8e0a..14f7d4a 100644 --- a/linden/indra/newview/llpanelgroupvoting.h +++ b/linden/indra/newview/llpanelgroupvoting.h @@ -2,6 +2,8 @@ * @file llpanelgroupvoting.h * @brief LLPanelGroupVoting class declaration. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELGROUPVOTING_H diff --git a/linden/indra/newview/llpanelinput.cpp b/linden/indra/newview/llpanelinput.cpp index ac2b453..d3a140c 100644 --- a/linden/indra/newview/llpanelinput.cpp +++ b/linden/indra/newview/llpanelinput.cpp @@ -2,6 +2,8 @@ * @file llpanelinput.cpp * @brief Input preferences panel * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llpanelinput.h b/linden/indra/newview/llpanelinput.h index e22f731..bfb6feb 100644 --- a/linden/indra/newview/llpanelinput.h +++ b/linden/indra/newview/llpanelinput.h @@ -2,6 +2,8 @@ * @file llpanelinput.h * @brief Input preferences panel * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_PANELINPUT_H diff --git a/linden/indra/newview/llpanelinventory.cpp b/linden/indra/newview/llpanelinventory.cpp index a7dc298..0223a56 100644 --- a/linden/indra/newview/llpanelinventory.cpp +++ b/linden/indra/newview/llpanelinventory.cpp @@ -2,6 +2,8 @@ * @file llpanelinventory.cpp * @brief LLPanelInventory class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //***************************************************************************** @@ -1849,11 +1852,8 @@ void LLPanelInventory::refresh() { //llinfos << "LLPanelInventory::refresh()" << llendl; BOOL has_inventory = FALSE; - LLSelectNode* node = gSelectMgr->getSelection()->getFirstRootNode(); - if(!node) - { - node = gSelectMgr->getSelection()->getFirstNode(); - } + const BOOL non_root_ok = TRUE; + LLSelectNode* node = gSelectMgr->getSelection()->getFirstRootNode(NULL, non_root_ok); if(node) { LLViewerObject* object = node->getObject(); diff --git a/linden/indra/newview/llpanelinventory.h b/linden/indra/newview/llpanelinventory.h index e56572b..4d6d6c7 100644 --- a/linden/indra/newview/llpanelinventory.h +++ b/linden/indra/newview/llpanelinventory.h @@ -2,6 +2,8 @@ * @file llpanelinventory.h * @brief LLPanelInventory class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //***************************************************************************** diff --git a/linden/indra/newview/llpanelland.cpp b/linden/indra/newview/llpanelland.cpp index d49972c..d86f81d 100644 --- a/linden/indra/newview/llpanelland.cpp +++ b/linden/indra/newview/llpanelland.cpp @@ -2,6 +2,8 @@ * @file llpanelland.cpp * @brief Land information in the tool floater, NOT the "About Land" floater * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,12 +26,11 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" -#include - #include "llpanelland.h" #include "llparcel.h" @@ -119,8 +120,8 @@ void LLPanelLandInfo::refresh() childSetVisible("label_area_price",false); childSetVisible("label_area",false); - //mTextPrice->setText(""); - childSetText("textbox price",""); + //mTextPrice->setText(LLString::null); + childSetText("textbox price",LLString::null); childSetEnabled("button buy land",FALSE); childSetEnabled("button abandon land",FALSE); diff --git a/linden/indra/newview/llpanelland.h b/linden/indra/newview/llpanelland.h index 397bf8d..7db8e64 100644 --- a/linden/indra/newview/llpanelland.h +++ b/linden/indra/newview/llpanelland.h @@ -2,6 +2,8 @@ * @file llpanelland.h * @brief Land information in the tool floater, NOT the "About Land" floater * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELLAND_H diff --git a/linden/indra/newview/llpanellandobjects.cpp b/linden/indra/newview/llpanellandobjects.cpp index c9992a6..bbda86a 100644 --- a/linden/indra/newview/llpanellandobjects.cpp +++ b/linden/indra/newview/llpanellandobjects.cpp @@ -3,6 +3,8 @@ * @brief Information about objects on a land parcel. * @author James Cook, Doug Soo * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llpanellandobjects.h b/linden/indra/newview/llpanellandobjects.h index daf3e35..7157e42 100644 --- a/linden/indra/newview/llpanellandobjects.h +++ b/linden/indra/newview/llpanellandobjects.h @@ -3,6 +3,8 @@ * @brief Information about objects on a land parcel. * @author James Cook, Doug Soo * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELLANDOBJECTS_H diff --git a/linden/indra/newview/llpanellandoptions.cpp b/linden/indra/newview/llpanellandoptions.cpp index 508954b..6eea82c 100644 --- a/linden/indra/newview/llpanellandoptions.cpp +++ b/linden/indra/newview/llpanellandoptions.cpp @@ -3,6 +3,8 @@ * @brief Options for a land parcel * @author James Cook, Douglas Soo * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llpanellandoptions.h b/linden/indra/newview/llpanellandoptions.h index 40d453e..6506793 100644 --- a/linden/indra/newview/llpanellandoptions.h +++ b/linden/indra/newview/llpanellandoptions.h @@ -3,6 +3,8 @@ * @brief * @autor James Cook, Douglas Soo * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELLANDOPTIONS_H diff --git a/linden/indra/newview/llpanellogin.cpp b/linden/indra/newview/llpanellogin.cpp index 2df1097..292f5c3 100644 --- a/linden/indra/newview/llpanellogin.cpp +++ b/linden/indra/newview/llpanellogin.cpp @@ -2,6 +2,8 @@ * @file llpanellogin.cpp * @brief Login dialog and logo display * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -51,6 +54,7 @@ #include "lltextbox.h" #include "llui.h" #include "lluiconstants.h" +#include "llurlsimstring.h" #include "llviewerbuild.h" #include "llviewerimagelist.h" #include "llviewermenu.h" // for handle_preferences() @@ -128,8 +132,6 @@ LLPanelLogin::LLPanelLogin(const LLRect &rect, mHtmlAvailable( TRUE ) { mIsFocusRoot = TRUE; - mMungedPassword[0] = '\0'; - mIncomingPassword[0] = '\0'; setBackgroundVisible(FALSE); setBackgroundOpaque(TRUE); @@ -342,7 +344,9 @@ void LLPanelLogin::mungePassword(LLUICtrl* caller, void* user_data) if (password != self->mIncomingPassword) { LLMD5 pass((unsigned char *)password.c_str()); - pass.hex_digest(self->mMungedPassword); + char munged_password[MD5HEX_STR_SIZE]; + pass.hex_digest(munged_password); + self->mMungedPassword = munged_password; } } @@ -555,19 +559,20 @@ void LLPanelLogin::setFields(const std::string& firstname, const std::string& la // We don't actually use the password input field, // fill it with MAX_PASSWORD characters so we get a // nice row of asterixes. - const char* filler = "123456789!123456"; + const std::string filler("123456789!123456"); sInstance->childSetText("password_edit", filler); - strcpy(sInstance->mIncomingPassword, filler); /*Flawfinder: ignore*/ - strcpy(sInstance->mMungedPassword, password.c_str()); /*Flawfinder: ignore*/ + sInstance->mIncomingPassword = filler; + sInstance->mMungedPassword = password; } else { // this is a normal text password sInstance->childSetText("password_edit", password); - strncpy(sInstance->mIncomingPassword, password.c_str(), sizeof(sInstance->mIncomingPassword) -1); /*Flawfinder: ignore*/ - sInstance->mIncomingPassword[sizeof(sInstance->mIncomingPassword) -1] = '\0'; + sInstance->mIncomingPassword = password; LLMD5 pass((unsigned char *)password.c_str()); - pass.hex_digest(sInstance->mMungedPassword); + char munged_password[MD5HEX_STR_SIZE]; + pass.hex_digest(munged_password); + sInstance->mMungedPassword = munged_password; } sInstance->childSetValue("remember_check", remember); @@ -607,7 +612,7 @@ void LLPanelLogin::getFields(LLString &firstname, LLString &lastname, LLString & lastname = sInstance->childGetText("last_name_edit"); LLString::trim(lastname); - password.assign( sInstance->mMungedPassword ); + password = sInstance->mMungedPassword; remember = sInstance->childGetValue("remember_check"); } diff --git a/linden/indra/newview/llpanellogin.h b/linden/indra/newview/llpanellogin.h index 7faf0d8..94e746e 100644 --- a/linden/indra/newview/llpanellogin.h +++ b/linden/indra/newview/llpanellogin.h @@ -2,6 +2,8 @@ * @file llpanellogin.h * @brief Login username entry fields. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELLOGIN_H @@ -93,8 +96,8 @@ private: void (*mCallback)(S32 option, void *userdata); void* mCallbackData; - char mIncomingPassword[DB_USER_PASSWORD_BUF_SIZE]; /*Flawfinder: ignore*/ - char mMungedPassword[MD5HEX_STR_SIZE]; /*Flawfinder: ignore*/ + std::string mIncomingPassword; + std::string mMungedPassword; static LLPanelLogin* sInstance; static BOOL sCapslockDidNotification; diff --git a/linden/indra/newview/llpanelmorph.cpp b/linden/indra/newview/llpanelmorph.cpp index 543e0e6..d05e551 100644 --- a/linden/indra/newview/llpanelmorph.cpp +++ b/linden/indra/newview/llpanelmorph.cpp @@ -2,6 +2,8 @@ * @file llpanelmorph.cpp * @brief LLPanelMorph class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // file include diff --git a/linden/indra/newview/llpanelmorph.h b/linden/indra/newview/llpanelmorph.h index 079f7d7..871b228 100644 --- a/linden/indra/newview/llpanelmorph.h +++ b/linden/indra/newview/llpanelmorph.h @@ -2,6 +2,8 @@ * @file llpanelmorph.h * @brief LLPanelMorph class definition * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /* diff --git a/linden/indra/newview/llpanelmsgs.cpp b/linden/indra/newview/llpanelmsgs.cpp index a758800..5306821 100644 --- a/linden/indra/newview/llpanelmsgs.cpp +++ b/linden/indra/newview/llpanelmsgs.cpp @@ -2,6 +2,8 @@ * @file llpanelmsgs.cpp * @brief Message popup preferences panel * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llpanelmsgs.h b/linden/indra/newview/llpanelmsgs.h index 72fc26a..668b353 100644 --- a/linden/indra/newview/llpanelmsgs.h +++ b/linden/indra/newview/llpanelmsgs.h @@ -2,6 +2,8 @@ * @file llpanelmsgs.h * @brief Message popup preferences panel * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELMSGS_H diff --git a/linden/indra/newview/llpanelnetwork.cpp b/linden/indra/newview/llpanelnetwork.cpp index 8676c33..3e1f6cb 100644 --- a/linden/indra/newview/llpanelnetwork.cpp +++ b/linden/indra/newview/llpanelnetwork.cpp @@ -2,6 +2,8 @@ * @file llpanelnetwork.cpp * @brief Network preferences panel * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llpanelnetwork.h b/linden/indra/newview/llpanelnetwork.h index 4d54f88..e90faef 100644 --- a/linden/indra/newview/llpanelnetwork.h +++ b/linden/indra/newview/llpanelnetwork.h @@ -2,6 +2,8 @@ * @file llpanelnetwork.h * @brief Network preferences panel * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELNETWORK_H diff --git a/linden/indra/newview/llpanelobject.cpp b/linden/indra/newview/llpanelobject.cpp index a8411df..cf50709 100644 --- a/linden/indra/newview/llpanelobject.cpp +++ b/linden/indra/newview/llpanelobject.cpp @@ -2,6 +2,8 @@ * @file llpanelobject.cpp * @brief Object editing (position, scale, etc.) in the tools floater * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -95,7 +98,7 @@ enum { MI_HOLE_COUNT }; -//XUI:translate (depricated, so very low priority) +//*TODO:translate (depricated, so very low priority) static const LLString LEGACY_FULLBRIGHT_DESC("Fullbright (Legacy)"); BOOL LLPanelObject::postBuild() @@ -160,7 +163,7 @@ BOOL LLPanelObject::postBuild() mComboMaterial = gUICtrlFactory->getComboBoxByName(this,"material"); childSetCommitCallback("material",onCommitMaterial,this); mComboMaterial->removeall(); - // XUI:translate + // *TODO:translate LLMaterialInfo *minfop; for (minfop = LLMaterialTable::basic.mMaterialInfoList.getFirstData(); minfop != NULL; @@ -506,8 +509,17 @@ void LLPanelObject::getState( ) #endif // Update material part - U8 material_code; - BOOL material_same = gSelectMgr->selectionGetMaterial(&material_code); + // slightly inefficient - materials are unique per object, not per TE + U8 material_code = 0; + struct f : public LLSelectedTEGetFunctor + { + U8 get(LLViewerObject* object, S32 te) + { + return object->getMaterial(); + } + } func; + bool material_same = gSelectMgr->getSelection()->getSelectedTEValue( &func, material_code ); + if (editable && single_volume && material_same) { mComboMaterial->setEnabled( TRUE ); @@ -526,7 +538,8 @@ void LLPanelObject::getState( ) { mComboMaterial->remove(LEGACY_FULLBRIGHT_DESC); } - mComboMaterial->setSimple(LLMaterialTable::basic.getName(material_code)); + // *TODO:Translate + mComboMaterial->setSimple(LLString(LLMaterialTable::basic.getName(material_code))); } } else diff --git a/linden/indra/newview/llpanelobject.h b/linden/indra/newview/llpanelobject.h index ac0b96c..87c9ce0 100644 --- a/linden/indra/newview/llpanelobject.h +++ b/linden/indra/newview/llpanelobject.h @@ -2,6 +2,8 @@ * @file llpanelobject.h * @brief Object editing (position, scale, etc.) in the tools floater * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELOBJECT_H diff --git a/linden/indra/newview/llpanelpermissions.cpp b/linden/indra/newview/llpanelpermissions.cpp index 0cfef5c..3d5723e 100644 --- a/linden/indra/newview/llpanelpermissions.cpp +++ b/linden/indra/newview/llpanelpermissions.cpp @@ -1,7 +1,11 @@ /** * @file llpanelpermissions.cpp * @brief LLPanelPermissions class implementation + * This class represents the panel in the build view for + * viewing/editing object names, owners, permissions, etc. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,15 +28,9 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ -//***************************************************************************** -// -// This class represents the panel in the build view for -// viewing/editing object names, owners, permissions, etc. -// -//***************************************************************************** - #include "llviewerprecompiledheaders.h" #include "llpanelpermissions.h" @@ -71,8 +69,13 @@ ///---------------------------------------------------------------------------- // Default constructor +LLPanelPermissions::LLPanelPermissions(const std::string& title) : + LLPanel(title) +{ + setMouseOpaque(FALSE); +} -BOOL LLPanelPermissions::postBuild() +BOOL LLPanelPermissions::postBuild() { this->childSetCommitCallback("Object Name",LLPanelPermissions::onCommitName,this); this->childSetPrevalidate("Object Name",LLLineEditor::prevalidatePrintableNotPipe); @@ -104,25 +107,23 @@ BOOL LLPanelPermissions::postBuild() this->childSetCommitCallback("checkbox next owner can copy",LLPanelPermissions::onCommitNextOwnerCopy,this); this->childSetCommitCallback("checkbox next owner can transfer",LLPanelPermissions::onCommitNextOwnerTransfer,this); this->childSetCommitCallback("clickaction",LLPanelPermissions::onCommitClickAction,this); - - LLTextBox* LabelGroupNameRectProxy = gUICtrlFactory->getTextBoxByName(this,"Group Name Proxy"); - if(LabelGroupNameRectProxy ) + this->childSetCommitCallback("search_check",LLPanelPermissions::onCommitIncludeInSearch,this); + + LLTextBox* group_rect_proxy = gUICtrlFactory->getTextBoxByName(this,"Group Name Proxy"); + if(group_rect_proxy ) { - mLabelGroupName = new LLNameBox("Group Name",LabelGroupNameRectProxy->getRect()); + mLabelGroupName = new LLNameBox("Group Name", group_rect_proxy->getRect()); addChild(mLabelGroupName); - }else + } + else + { mLabelGroupName = NULL; + } return TRUE; } -LLPanelPermissions::LLPanelPermissions(const std::string& title) : - LLPanel(title) -{ - setMouseOpaque(FALSE); -} -// Destroys the object LLPanelPermissions::~LLPanelPermissions() { // base class will take care of everything @@ -131,7 +132,6 @@ LLPanelPermissions::~LLPanelPermissions() void LLPanelPermissions::refresh() { - LLButton* BtnDeedToGroup = gUICtrlFactory->getButtonByName(this,"button deed"); if(BtnDeedToGroup) { @@ -165,33 +165,33 @@ void LLPanelPermissions::refresh() { // ...nothing selected childSetEnabled("perm_modify",false); - childSetText("perm_modify",""); + childSetText("perm_modify",LLString::null); childSetEnabled("Creator:",false); - childSetText("Creator Name",""); + childSetText("Creator Name",LLString::null); childSetEnabled("Creator Name",false); childSetEnabled("button creator profile",false); childSetEnabled("Owner:",false); - childSetText("Owner Name",""); + childSetText("Owner Name",LLString::null); childSetEnabled("Owner Name",false); childSetEnabled("button owner profile",false); childSetEnabled("Group:",false); - childSetText("Group Name",""); + childSetText("Group Name",LLString::null); childSetEnabled("Group Name",false); childSetEnabled("button set group",false); - childSetText("Object Name",""); + childSetText("Object Name",LLString::null); childSetEnabled("Object Name",false); childSetEnabled("Name:",false); - childSetText("Group Name",""); + childSetText("Group Name",LLString::null); childSetEnabled("Group Name",false); childSetEnabled("Description:",false); - childSetText("Object Description",""); + childSetText("Object Description",LLString::null); childSetEnabled("Object Description",false); - childSetText("prim info",""); + childSetText("prim info",LLString::null); childSetEnabled("prim info",false); childSetEnabled("Permissions:",false); @@ -217,6 +217,10 @@ void LLPanelPermissions::refresh() //checkbox for sale childSetValue("checkbox for sale",FALSE); childSetEnabled("checkbox for sale",false); + + //checkbox include in search + childSetValue("search_check", FALSE); + childSetEnabled("search_check", false); LLRadioGroup* RadioSaleType = gUICtrlFactory->getRadioGroupByName(this,"sale type"); if(RadioSaleType) @@ -226,7 +230,7 @@ void LLPanelPermissions::refresh() } childSetEnabled("Price: L$",false); - childSetText("EdCost",false); + childSetText("EdCost",LLString::null); childSetEnabled("EdCost",false); childSetEnabled("label click action",false); @@ -417,7 +421,7 @@ void LLPanelPermissions::refresh() if(!owners_identical) { childSetEnabled("Price: L$",false); - childSetText("EdCost",""); + childSetText("EdCost",LLString::null); childSetEnabled("EdCost",false); } else if(self_owned || (group_owned && gAgent.hasPowerInGroup(group_id,GP_OBJECT_SET_SALE))) @@ -449,7 +453,7 @@ void LLPanelPermissions::refresh() { // ...public object childSetEnabled("Price: L$",false); - childSetText("EdCost",""); + childSetText("EdCost",LLString::null); childSetEnabled("EdCost",false); } @@ -497,36 +501,35 @@ void LLPanelPermissions::refresh() if( gSavedSettings.getBOOL("DebugPermissions") ) { - char perm_string[10]; /*Flawfinder: ignore*/ + std::string perm_string; if (valid_base_perms) { - - strcpy(perm_string, "B: "); /*Flawfinder: ignore*/ - mask_to_string(base_mask_on, perm_string+3); + perm_string = "B: "; + perm_string += mask_to_string(base_mask_on); childSetText("B:",perm_string); childSetVisible("B:",true); - strcpy(perm_string, "O: "); /*Flawfinder: ignore*/ - mask_to_string(owner_mask_on, perm_string+3); + perm_string = "O: "; + perm_string += mask_to_string(owner_mask_on); childSetText("O:",perm_string); childSetVisible("O:",true); - strcpy(perm_string, "G: "); /*Flawfinder: ignore*/ - mask_to_string(group_mask_on, perm_string+3); + perm_string = "G: "; + perm_string += mask_to_string(group_mask_on); childSetText("G:",perm_string); childSetVisible("G:",true); - strcpy(perm_string, "E: "); /*Flawfinder: ignore*/ - mask_to_string(everyone_mask_on, perm_string+3); + perm_string = "E: "; + perm_string += mask_to_string(everyone_mask_on); childSetText("E:",perm_string); childSetVisible("E:",true); - strcpy(perm_string, "N: "); /*Flawfinder: ignore*/ - mask_to_string(next_owner_mask_on, perm_string+3); + perm_string = "N: "; + perm_string += mask_to_string(next_owner_mask_on); childSetText("N:",perm_string); childSetVisible("N:",true); } - strcpy(perm_string, "F: "); /*Flawfinder: ignore*/ + perm_string = "F: "; U32 flag_mask = 0x0; if (objectp->permMove()) flag_mask |= PERM_MOVE; @@ -536,7 +539,7 @@ void LLPanelPermissions::refresh() flag_mask |= PERM_COPY; if (objectp->permTransfer()) flag_mask |= PERM_TRANSFER; - mask_to_string(flag_mask, perm_string+3); + perm_string += mask_to_string(flag_mask); childSetText("F:",perm_string); childSetVisible("F:",true); } @@ -568,9 +571,8 @@ void LLPanelPermissions::refresh() if (!has_change_perm_ability && !has_change_sale_ability && !root_selected) { - // XUI:translate // ...must select root to choose permissions - childSetValue("perm_modify", "Must select entire object to set permissions."); + childSetValue("perm_modify", childGetText("text modify warning")); } if (has_change_perm_ability) @@ -613,7 +615,7 @@ void LLPanelPermissions::refresh() { childSetValue("checkbox share with group",TRUE); childSetTentative("checkbox share with group",FALSE); - childSetEnabled("button deed",gAgent.hasPowerInGroup(group_id, GP_OBJECT_DEED) && (owner_mask_on & PERM_TRANSFER) && !group_owned); + childSetEnabled("button deed",gAgent.hasPowerInGroup(group_id, GP_OBJECT_DEED) && (owner_mask_on & PERM_TRANSFER) && !group_owned && can_transfer); } else if((group_mask_off & PERM_COPY) && (group_mask_off & PERM_MODIFY) && (group_mask_off & PERM_MOVE)) { @@ -625,7 +627,7 @@ void LLPanelPermissions::refresh() { childSetValue("checkbox share with group",TRUE); childSetTentative("checkbox share with group",true); - childSetEnabled("button deed",gAgent.hasPowerInGroup(group_id, GP_OBJECT_DEED) && (group_mask_on & PERM_MOVE) && (owner_mask_on & PERM_TRANSFER) && !group_owned); + childSetEnabled("button deed",gAgent.hasPowerInGroup(group_id, GP_OBJECT_DEED) && (group_mask_on & PERM_MOVE) && (owner_mask_on & PERM_TRANSFER) && !group_owned && can_transfer); } } @@ -750,8 +752,15 @@ void LLPanelPermissions::refresh() childSetTentative("checkbox for sale",false); } - // Click action (touch, sit, buy) + // Check search status of objects BOOL all_volume = gSelectMgr->selectionAllPCode( LL_PCODE_VOLUME ); + bool include_in_search; + bool all_include_in_search = gSelectMgr->selectionGetIncludeInSearch(&include_in_search); + childSetEnabled("search_check", is_perm_modify && all_volume); + childSetValue("search_check", include_in_search); + childSetTentative("search_check", ! all_include_in_search); + + // Click action (touch, sit, buy) U8 click_action = 0; if (gSelectMgr->selectionGetClickAction(&click_action)) { @@ -1016,9 +1025,8 @@ void LLPanelPermissions::setAllSaleInfo() } } -class LLSelectionPayable : public LLSelectedObjectFunctor +struct LLSelectionPayable : public LLSelectedObjectFunctor { -public: virtual bool apply(LLViewerObject* obj) { // can pay if you or your parent has money() event in script @@ -1064,3 +1072,13 @@ void LLPanelPermissions::onCommitClickAction(LLUICtrl* ctrl, void*) } gSelectMgr->selectionSetClickAction(click_action); } + +// static +void LLPanelPermissions::onCommitIncludeInSearch(LLUICtrl* ctrl, void*) +{ + LLCheckBoxCtrl* box = (LLCheckBoxCtrl*)ctrl; + llassert(box); + + gSelectMgr->selectionSetIncludeInSearch(box->get()); +} + diff --git a/linden/indra/newview/llpanelpermissions.h b/linden/indra/newview/llpanelpermissions.h index 9cf7a82..efd3430 100644 --- a/linden/indra/newview/llpanelpermissions.h +++ b/linden/indra/newview/llpanelpermissions.h @@ -2,6 +2,8 @@ * @file llpanelpermissions.h * @brief LLPanelPermissions class header file * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,15 +26,13 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELPERMISSIONS_H #define LL_LLPANELPERMISSIONS_H -#ifndef LL_LLPANEL_H #include "llpanel.h" -#endif - #include "lluuid.h" //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ @@ -95,6 +95,7 @@ protected: void setAllSaleInfo(); static void onCommitClickAction(LLUICtrl* ctrl, void*); + static void onCommitIncludeInSearch(LLUICtrl* ctrl, void*); protected: LLNameBox* mLabelGroupName; // group name diff --git a/linden/indra/newview/llpanelpick.cpp b/linden/indra/newview/llpanelpick.cpp index 9dc0aea..cd25131 100644 --- a/linden/indra/newview/llpanelpick.cpp +++ b/linden/indra/newview/llpanelpick.cpp @@ -2,6 +2,8 @@ * @file llpanelpick.cpp * @brief LLPanelPick class implementation * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Display of a "Top Pick" used both for the global top picks in the @@ -324,8 +327,7 @@ void LLPanelPick::processPickInfoReply(LLMessageSystem *msg, void **) S32 region_y = llround((F32)pos_global.mdV[VY]) % REGION_WIDTH_UNITS; S32 region_z = llround((F32)pos_global.mdV[VZ]); - snprintf(buffer, sizeof(buffer), "%s (%d, %d, %d)", sim_name, region_x, region_y, region_z); /* Flawfinder: ignore */ - location_text.append(buffer); + location_text.append(llformat("%s (%d, %d, %d)", sim_name, region_x, region_y, region_z)); S32 sort_order; msg->getS32("Data", "SortOrder", sort_order); @@ -353,14 +355,13 @@ void LLPanelPick::processPickInfoReply(LLMessageSystem *msg, void **) self->mPosGlobal = pos_global; // Update UI controls - self->mNameEditor->setText(name); - self->mDescEditor->setText(desc); + self->mNameEditor->setText(LLString(name)); + self->mDescEditor->setText(LLString(desc)); self->mSnapshotCtrl->setImageAssetID(snapshot_id); self->mLocationEditor->setText(location_text); self->mEnabledCheck->set(enabled); - snprintf(buffer, sizeof(buffer), "%d", sort_order); /* Flawfinder: ignore */ - self->mSortOrderEditor->setText(buffer); + self->mSortOrderEditor->setText(llformat("%d", sort_order)); } } diff --git a/linden/indra/newview/llpanelpick.h b/linden/indra/newview/llpanelpick.h index 21072e4..d0ab562 100644 --- a/linden/indra/newview/llpanelpick.h +++ b/linden/indra/newview/llpanelpick.h @@ -2,6 +2,8 @@ * @file llpanelpick.h * @brief LLPanelPick class definition * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Display of a "Top Pick" used both for the global top picks in the diff --git a/linden/indra/newview/llpanelplace.cpp b/linden/indra/newview/llpanelplace.cpp index a9f11cc..2176fdc 100644 --- a/linden/indra/newview/llpanelplace.cpp +++ b/linden/indra/newview/llpanelplace.cpp @@ -2,6 +2,8 @@ * @file llpanelplace.cpp * @brief Display of a place in the Find directory. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -153,7 +156,6 @@ void LLPanelPlace::processParcelInfoReply(LLMessageSystem *msg, void **) F32 dwell; S32 sale_price; S32 auction_id; - char buffer[256]; /*Flawfinder: ignore*/ msg->getUUID("AgentData", "AgentID", agent_id ); msg->getUUID("Data", "ParcelID", parcel_id); @@ -188,29 +190,35 @@ void LLPanelPlace::processParcelInfoReply(LLMessageSystem *msg, void **) self->mSnapshotCtrl->setImageAssetID(snapshot_id); - self->mNameEditor->setText(name); + self->mNameEditor->setText(LLString(name)); - self->mDescEditor->setText(desc); + self->mDescEditor->setText(LLString(desc)); - LLString info; - snprintf(buffer, sizeof(buffer), "Traffic: %.0f, Area: %d sq. m.", dwell, actual_area); /* Flawfinder: ignore */ - info.append(buffer); + LLString info_text; + LLUIString traffic = self->childGetText("traffic_text"); + traffic.setArg("[TRAFFIC]", llformat("%.0f", dwell)); + info_text = traffic; + LLUIString area = self->childGetText("area_text"); + traffic.setArg("[AREA]", llformat("%d", actual_area)); + info_text += area; if (flags & DFQ_FOR_SALE) { - snprintf(buffer, sizeof(buffer), ", For Sale for L$%d", sale_price); /* Flawfinder: ignore */ - info.append(buffer); + LLUIString forsale = self->childGetText("forsale_text"); + traffic.setArg("[PRICE]", llformat("%d", sale_price)); + info_text += forsale; } if (auction_id != 0) { - snprintf(buffer, sizeof(buffer), ", Auction ID %010d", auction_id); /* Flawfinder: ignore */ - info.append(buffer); + LLUIString auction = self->childGetText("auction_text"); + auction.setArg("[ID]", llformat("%010d", auction_id)); + info_text += auction; } - self->mInfoEditor->setText(info); + self->mInfoEditor->setText(info_text); S32 region_x = llround(global_x) % REGION_WIDTH_UNITS; S32 region_y = llround(global_y) % REGION_WIDTH_UNITS; S32 region_z = llround(global_z); - + // HACK: Flag 0x1 == mature region, otherwise assume PG const char* rating = LLViewerRegion::accessToString(SIM_ACCESS_PG); if (flags & 0x1) @@ -218,9 +226,9 @@ void LLPanelPlace::processParcelInfoReply(LLMessageSystem *msg, void **) rating = LLViewerRegion::accessToString(SIM_ACCESS_MATURE); } - snprintf(buffer, sizeof(buffer), "%s %d, %d, %d (%s)", /* Flawfinder: ignore */ - sim_name, region_x, region_y, region_z, rating); - self->mLocationEditor->setText(buffer); + LLString location = llformat("%s %d, %d, %d (%s)", + sim_name, region_x, region_y, region_z, rating); + self->mLocationEditor->setText(location); BOOL show_auction = (auction_id > 0); self->mAuctionBtn->setVisible(show_auction); diff --git a/linden/indra/newview/llpanelplace.h b/linden/indra/newview/llpanelplace.h index 65dd591..81a2a63 100644 --- a/linden/indra/newview/llpanelplace.h +++ b/linden/indra/newview/llpanelplace.h @@ -2,6 +2,8 @@ * @file llpanelplace.h * @brief Display of a place in the Find directory. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELPLACE_H diff --git a/linden/indra/newview/llpanelvolume.cpp b/linden/indra/newview/llpanelvolume.cpp index a91eeb7..69e0fde 100644 --- a/linden/indra/newview/llpanelvolume.cpp +++ b/linden/indra/newview/llpanelvolume.cpp @@ -2,6 +2,8 @@ * @file llpanelvolume.cpp * @brief Object editing (position, scale, etc.) in the tools floater * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llpanelvolume.h b/linden/indra/newview/llpanelvolume.h index 3f254aa..38321eb 100644 --- a/linden/indra/newview/llpanelvolume.h +++ b/linden/indra/newview/llpanelvolume.h @@ -2,6 +2,8 @@ * @file llpanelvolume.h * @brief Object editing (position, scale, etc.) in the tools floater * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELVOLUME_H diff --git a/linden/indra/newview/llpanelweb.cpp b/linden/indra/newview/llpanelweb.cpp index 5b0b7e6..2b91bd2 100644 --- a/linden/indra/newview/llpanelweb.cpp +++ b/linden/indra/newview/llpanelweb.cpp @@ -2,6 +2,8 @@ * @file LLPanelWeb.cpp * @brief Network preferences panel * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -58,7 +61,7 @@ BOOL LLPanelWeb::postBuild() { childSetAction( "clear_cache", onClickClearCache, this ); childSetAction( "clear_cookies", onClickClearCookies, this ); - childSetEnabled( "connection_port", gSavedSettings.getBOOL( "CookiesEnabled" ) ); +// childSetEnabled( "connection_port", gSavedSettings.getBOOL( "CookiesEnabled" ) ); childSetCommitCallback( "cookies_enabled", onCommitCookies, this ); refresh(); diff --git a/linden/indra/newview/llpanelweb.h b/linden/indra/newview/llpanelweb.h index 48b0742..3d80aae 100644 --- a/linden/indra/newview/llpanelweb.h +++ b/linden/indra/newview/llpanelweb.h @@ -2,6 +2,8 @@ * @file llpanelweb.h * @brief Web browser preferences panel * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPANELWEB_H diff --git a/linden/indra/newview/llpatchvertexarray.cpp b/linden/indra/newview/llpatchvertexarray.cpp index 611ff97..70be4a7 100644 --- a/linden/indra/newview/llpatchvertexarray.cpp +++ b/linden/indra/newview/llpatchvertexarray.cpp @@ -2,6 +2,8 @@ * @file llpatchvertexarray.cpp * @brief Implementation of the LLSurfaceVertexArray class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llpatchvertexarray.h b/linden/indra/newview/llpatchvertexarray.h index f123c87..bd47212 100644 --- a/linden/indra/newview/llpatchvertexarray.h +++ b/linden/indra/newview/llpatchvertexarray.h @@ -2,6 +2,8 @@ * @file llpatchvertexarray.h * @brief description of Surface class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPATCHVERTEXARRAY_H diff --git a/linden/indra/newview/llpolymesh.cpp b/linden/indra/newview/llpolymesh.cpp index 6cc3fc7..492e590 100644 --- a/linden/indra/newview/llpolymesh.cpp +++ b/linden/indra/newview/llpolymesh.cpp @@ -2,6 +2,8 @@ * @file llpolymesh.cpp * @brief Implementation of LLPolyMesh class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- diff --git a/linden/indra/newview/llpolymesh.h b/linden/indra/newview/llpolymesh.h index a421e05..3cf4acb 100644 --- a/linden/indra/newview/llpolymesh.h +++ b/linden/indra/newview/llpolymesh.h @@ -2,6 +2,8 @@ * @file llpolymesh.h * @brief Implementation of LLPolyMesh class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPOLYMESH_H diff --git a/linden/indra/newview/llpolymorph.cpp b/linden/indra/newview/llpolymorph.cpp index b36f0e2..107b51d 100644 --- a/linden/indra/newview/llpolymorph.cpp +++ b/linden/indra/newview/llpolymorph.cpp @@ -2,6 +2,8 @@ * @file llpolymorph.cpp * @brief Implementation of LLPolyMesh class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- diff --git a/linden/indra/newview/llpolymorph.h b/linden/indra/newview/llpolymorph.h index f867d27..0d6ebc3 100644 --- a/linden/indra/newview/llpolymorph.h +++ b/linden/indra/newview/llpolymorph.h @@ -2,6 +2,8 @@ * @file llpolymorph.h * @brief Implementation of LLPolyMesh class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPOLYMORPH_H diff --git a/linden/indra/newview/llprefschat.cpp b/linden/indra/newview/llprefschat.cpp index 91cacd9..a227922 100644 --- a/linden/indra/newview/llprefschat.cpp +++ b/linden/indra/newview/llprefschat.cpp @@ -3,6 +3,8 @@ * @author James Cook, Richard Nelson * @brief Chat preferences panel * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llprefschat.h b/linden/indra/newview/llprefschat.h index 71868f7..70c4b57 100644 --- a/linden/indra/newview/llprefschat.h +++ b/linden/indra/newview/llprefschat.h @@ -2,6 +2,8 @@ * @file llprefschat.h * @brief Chat preferences panel * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLPREFSCHAT_H diff --git a/linden/indra/newview/llprefsim.cpp b/linden/indra/newview/llprefsim.cpp index fad1742..84efbb1 100644 --- a/linden/indra/newview/llprefsim.cpp +++ b/linden/indra/newview/llprefsim.cpp @@ -3,6 +3,8 @@ * @author James Cook, Richard Nelson * @brief Instant messsage preferences panel * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llprefsim.h b/linden/indra/newview/llprefsim.h index 411253b..dbc1925 100644 --- a/linden/indra/newview/llprefsim.h +++ b/linden/indra/newview/llprefsim.h @@ -3,6 +3,8 @@ * @author James Cook, Richard Nelson * @brief Instant message preferences panel * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLPANELPREFSIM_H diff --git a/linden/indra/newview/llprefsvoice.cpp b/linden/indra/newview/llprefsvoice.cpp index c5788d6..59619d6 100644 --- a/linden/indra/newview/llprefsvoice.cpp +++ b/linden/indra/newview/llprefsvoice.cpp @@ -3,6 +3,8 @@ * @author Richard Nelson * @brief Voice chat preferences panel * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llprefsvoice.h b/linden/indra/newview/llprefsvoice.h index 4e48fd7..f09bc6c 100644 --- a/linden/indra/newview/llprefsvoice.h +++ b/linden/indra/newview/llprefsvoice.h @@ -2,6 +2,8 @@ * @file llprefsvoice.h * @brief Voice chat preferences panel * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLPREFSVOICE_H diff --git a/linden/indra/newview/llpreview.cpp b/linden/indra/newview/llpreview.cpp index 4993852..e4f7d1e 100644 --- a/linden/indra/newview/llpreview.cpp +++ b/linden/indra/newview/llpreview.cpp @@ -2,6 +2,8 @@ * @file llpreview.cpp * @brief LLPreview class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llpreview.h b/linden/indra/newview/llpreview.h index dcf7fbb..ae986f5 100644 --- a/linden/indra/newview/llpreview.h +++ b/linden/indra/newview/llpreview.h @@ -2,6 +2,8 @@ * @file llpreview.h * @brief LLPreview class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPREVIEW_H diff --git a/linden/indra/newview/llpreviewanim.cpp b/linden/indra/newview/llpreviewanim.cpp index 2eb3b75..f6d5d9d 100644 --- a/linden/indra/newview/llpreviewanim.cpp +++ b/linden/indra/newview/llpreviewanim.cpp @@ -2,6 +2,8 @@ * @file llpreviewanim.cpp * @brief LLPreviewAnim class implementation * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llpreviewanim.h b/linden/indra/newview/llpreviewanim.h index 318d36e..bb6ec75 100644 --- a/linden/indra/newview/llpreviewanim.h +++ b/linden/indra/newview/llpreviewanim.h @@ -2,6 +2,8 @@ * @file llpreviewanim.h * @brief LLPreviewAnim class definition * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPREVIEWANIM_H diff --git a/linden/indra/newview/llpreviewgesture.cpp b/linden/indra/newview/llpreviewgesture.cpp index 1afa523..720963c 100644 --- a/linden/indra/newview/llpreviewgesture.cpp +++ b/linden/indra/newview/llpreviewgesture.cpp @@ -2,6 +2,8 @@ * @file llpreviewgesture.cpp * @brief Editing UI for inventory-based gestures. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -66,6 +69,7 @@ #include "llresmgr.h" +// *TODO: Translate? const char NONE_LABEL[] = "---"; const char SHIFT_LABEL[] = "Shift"; const char CTRL_LABEL[] = "Ctrl"; @@ -147,6 +151,13 @@ LLPreviewGesture* LLPreviewGesture::show(const std::string& title, const LLUUID& hostp->addFloater(self, TRUE); } + // Start speculative download of sounds and animations + LLUUID animation_folder_id = gInventory.findCategoryUUIDForType(LLAssetType::AT_ANIMATION); + gInventory.startBackgroundFetch(animation_folder_id); + + LLUUID sound_folder_id = gInventory.findCategoryUUIDForType(LLAssetType::AT_SOUND); + gInventory.startBackgroundFetch(sound_folder_id); + // this will call refresh when we have everything. LLViewerInventoryItem* item = (LLViewerInventoryItem*)self->getItem(); if(item && !item->isComplete()) @@ -289,6 +300,12 @@ void LLPreviewGesture::onClose(bool app_quitting) } // virtual +void LLPreviewGesture::onUpdateSucceeded() +{ + refresh(); +} + +// virtual void LLPreviewGesture::setMinimized(BOOL minimize) { if (minimize != isMinimized()) @@ -567,8 +584,10 @@ void LLPreviewGesture::addAnimations() LLComboBox* combo = mAnimationCombo; combo->removeall(); + + LLString none_text = childGetText("none_text"); - combo->add("-- None --", LLUUID::null); + combo->add(none_text, LLUUID::null); // Add all the default (legacy) animations S32 i; @@ -618,6 +637,13 @@ void LLPreviewGesture::addAnimations() void LLPreviewGesture::addSounds() { + LLComboBox* combo = mSoundCombo; + combo->removeall(); + + LLString none_text = childGetText("none_text"); + + combo->add(none_text, LLUUID::null); + // Get all inventory items that are sounds LLViewerInventoryCategory::cat_array_t cats; LLViewerInventoryItem::item_array_t items; @@ -645,8 +671,6 @@ void LLPreviewGesture::addSounds() std::sort(sounds.begin(), sounds.end(), SortItemPtrsByName()); // And load up the combobox - LLComboBox* combo = mSoundCombo; - combo->removeall(); std::vector::iterator it; for (it = sounds.begin(); it != sounds.end(); ++it) { @@ -752,17 +776,20 @@ void LLPreviewGesture::refresh() mWaitTimeCheck->setVisible(FALSE); mWaitTimeEditor->setVisible(FALSE); + LLString optionstext; + if (have_step) { // figure out the type, show proper options, update text LLGestureStep* step = (LLGestureStep*)step_item->getUserdata(); EStepType type = step->getType(); + switch(type) { case STEP_ANIMATION: { LLGestureStepAnimation* anim_step = (LLGestureStepAnimation*)step; - mOptionsText->setText("Animation to play:"); + optionstext = childGetText("step_anim"); mAnimationCombo->setVisible(TRUE); mAnimationRadio->setVisible(TRUE); mAnimationRadio->setSelectedIndex((anim_step->mFlags & ANIM_FLAG_STOP) ? 1 : 0); @@ -772,7 +799,7 @@ void LLPreviewGesture::refresh() case STEP_SOUND: { LLGestureStepSound* sound_step = (LLGestureStepSound*)step; - mOptionsText->setText("Sound to play:"); + optionstext = childGetText("step_sound"); mSoundCombo->setVisible(TRUE); mSoundCombo->setCurrentByID(sound_step->mSoundAssetID); break; @@ -780,7 +807,7 @@ void LLPreviewGesture::refresh() case STEP_CHAT: { LLGestureStepChat* chat_step = (LLGestureStepChat*)step; - mOptionsText->setText("Chat to say:"); + optionstext = childGetText("step_chat"); mChatEditor->setVisible(TRUE); mChatEditor->setText(chat_step->mChatText); break; @@ -788,14 +815,13 @@ void LLPreviewGesture::refresh() case STEP_WAIT: { LLGestureStepWait* wait_step = (LLGestureStepWait*)step; - mOptionsText->setText("Wait:"); + optionstext = childGetText("step_wait"); mWaitAnimCheck->setVisible(TRUE); mWaitAnimCheck->set(wait_step->mFlags & WAIT_FLAG_ALL_ANIM); mWaitTimeCheck->setVisible(TRUE); mWaitTimeCheck->set(wait_step->mFlags & WAIT_FLAG_TIME); mWaitTimeEditor->setVisible(TRUE); - char buffer[16]; /*Flawfinder: ignore*/ - snprintf(buffer, sizeof(buffer), "%.1f", (double)wait_step->mWaitSeconds); /* Flawfinder: ignore */ + std::string buffer = llformat("%.1f", (double)wait_step->mWaitSeconds); mWaitTimeEditor->setText(buffer); break; } @@ -803,11 +829,8 @@ void LLPreviewGesture::refresh() break; } } - else - { - // no gesture - mOptionsText->setText(""); - } + + mOptionsText->setText(optionstext); BOOL active = gGestureManager.isGestureActive(mItemUUID); mActiveCheck->set(active); @@ -975,14 +998,14 @@ void LLPreviewGesture::loadUIFromGesture(LLMultiGesture* gesture) switch (gesture->mMask) { default: - case MASK_NONE: - mModifierCombo->setSimple( NONE_LABEL ); + case MASK_NONE: + mModifierCombo->setSimple( LLString(NONE_LABEL) ); break; - case MASK_SHIFT: - mModifierCombo->setSimple( SHIFT_LABEL ); + case MASK_SHIFT: + mModifierCombo->setSimple( LLString(SHIFT_LABEL) ); break; - case MASK_CONTROL: - mModifierCombo->setSimple( CTRL_LABEL ); + case MASK_CONTROL: + mModifierCombo->setSimple( LLString(CTRL_LABEL) ); break; } @@ -1120,19 +1143,29 @@ void LLPreviewGesture::saveIfNeeded() file.setMaxSize(size); file.write((U8*)buffer, size); + BOOL delayedUpload = FALSE; + // Upload that asset to the database - const LLInventoryItem* item = getItem(); + LLViewerInventoryItem* item = (LLViewerInventoryItem*) getItem(); if (item) { std::string agent_url = gAgent.getRegion()->getCapability("UpdateGestureAgentInventory"); std::string task_url = gAgent.getRegion()->getCapability("UpdateGestureTaskInventory"); if (mObjectUUID.isNull() && !agent_url.empty()) { + //need to disable the preview floater so item + //isn't re-saved before new asset arrives + //fake out refresh. + item->setComplete(FALSE); + refresh(); + item->setComplete(TRUE); + // Saving into agent inventory LLSD body; body["item_id"] = mItemUUID; LLHTTPClient::post(agent_url, body, new LLUpdateAgentInventoryResponder(body, asset_id, LLAssetType::AT_GESTURE)); + delayedUpload = TRUE; } else if (!mObjectUUID.isNull() && !task_url.empty()) { @@ -1153,7 +1186,7 @@ void LLPreviewGesture::saveIfNeeded() // If this gesture is active, then we need to update the in-memory // active map with the new pointer. - if (gGestureManager.isGestureActive(mItemUUID)) + if (!delayedUpload && gGestureManager.isGestureActive(mItemUUID)) { // gesture manager now owns the pointer gGestureManager.replaceGesture(mItemUUID, gesture, asset_id); @@ -1170,7 +1203,12 @@ void LLPreviewGesture::saveIfNeeded() } mDirty = FALSE; - refresh(); + // refresh will be called when callback + // if triggered when delayedUpload + if(!delayedUpload) + { + refresh(); + } } delete [] buffer; @@ -1710,8 +1748,7 @@ void LLPreviewGesture::onClickPreview(void* data) self->mPreviewGesture->mCallbackData = self; // set the button title - self->mPreviewBtn->setLabelSelected("Stop"); - self->mPreviewBtn->setLabelUnselected("Stop"); + self->mPreviewBtn->setLabel(self->childGetText("stop_txt")); // play it, and delete when done gGestureManager.playGesture(self->mPreviewGesture); @@ -1733,8 +1770,7 @@ void LLPreviewGesture::onDonePreview(LLMultiGesture* gesture, void* data) { LLPreviewGesture* self = (LLPreviewGesture*)data; - self->mPreviewBtn->setLabelSelected("Preview"); - self->mPreviewBtn->setLabelUnselected("Preview"); + self->mPreviewBtn->setLabel(self->childGetText("preview_txt")); delete self->mPreviewGesture; self->mPreviewGesture = NULL; diff --git a/linden/indra/newview/llpreviewgesture.h b/linden/indra/newview/llpreviewgesture.h index a7abb7e..5c84ee0 100644 --- a/linden/indra/newview/llpreviewgesture.h +++ b/linden/indra/newview/llpreviewgesture.h @@ -2,6 +2,8 @@ * @file llpreviewgesture.h * @brief Editing UI for inventory-based gestures. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPREVIEWGESTURE_H @@ -64,6 +67,7 @@ public: virtual BOOL canClose(); virtual void setMinimized(BOOL minimize); virtual void onClose(bool app_quitting); + virtual void onUpdateSucceeded(); protected: diff --git a/linden/indra/newview/llpreviewlandmark.cpp b/linden/indra/newview/llpreviewlandmark.cpp index 62d103b..ac1bd3f 100644 --- a/linden/indra/newview/llpreviewlandmark.cpp +++ b/linden/indra/newview/llpreviewlandmark.cpp @@ -2,6 +2,8 @@ * @file llpreviewlandmark.cpp * @brief LLPreviewLandmark class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -239,8 +242,6 @@ void LLPreviewLandmark::draw() // See also llfloatermap.cpp -> onLandmarkGo childSetEnabled("Teleport btn", TRUE); - LLButton* teleportBtn = LLUICtrlFactory::getButtonByName(this, "Teleport btn"); - teleportBtn->setLabelUnselected("Teleport"); } BOOL in_prelude = gAgent.inPrelude(); diff --git a/linden/indra/newview/llpreviewlandmark.h b/linden/indra/newview/llpreviewlandmark.h index ff3f88c..91088b0 100644 --- a/linden/indra/newview/llpreviewlandmark.h +++ b/linden/indra/newview/llpreviewlandmark.h @@ -2,6 +2,8 @@ * @file llpreviewlandmark.h * @brief LLPreviewLandmark class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPREVIEWLANDMARK_H diff --git a/linden/indra/newview/llpreviewnotecard.cpp b/linden/indra/newview/llpreviewnotecard.cpp index ce37d64..620be8f 100644 --- a/linden/indra/newview/llpreviewnotecard.cpp +++ b/linden/indra/newview/llpreviewnotecard.cpp @@ -2,6 +2,8 @@ * @file llpreviewnotecard.cpp * @brief Implementation of the notecard editor * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -278,7 +281,7 @@ void LLPreviewNotecard::loadAsset() mAssetID = item->getAssetUUID(); if(mAssetID.isNull()) { - editor->setText(""); + editor->setText(LLString::null); editor->makePristine(); editor->setEnabled(TRUE); mAssetStatus = PREVIEW_ASSET_LOADED; @@ -299,7 +302,7 @@ void LLPreviewNotecard::loadAsset() // The object that we're trying to look at disappeared, bail. llwarns << "Can't find object " << mObjectUUID << " associated with notecard." << llendl; mAssetID.setNull(); - editor->setText("Unable to find object containing this note."); + editor->setText(childGetText("no_object")); editor->makePristine(); editor->setEnabled(FALSE); mAssetStatus = PREVIEW_ASSET_LOADED; @@ -324,7 +327,7 @@ void LLPreviewNotecard::loadAsset() else { mAssetID.setNull(); - editor->setText("You are not allowed to view this note."); + editor->setText(childGetText("not_allowed")); editor->makePristine(); editor->setEnabled(FALSE); mAssetStatus = PREVIEW_ASSET_LOADED; @@ -338,7 +341,7 @@ void LLPreviewNotecard::loadAsset() } else { - editor->setText(""); + editor->setText(LLString::null); editor->makePristine(); editor->setEnabled(TRUE); mAssetStatus = PREVIEW_ASSET_LOADED; @@ -381,7 +384,7 @@ void LLPreviewNotecard::onLoadComplete(LLVFS *vfs, else { // Version 0 (just text, doesn't include version number) - previewEditor->setText(buffer); + previewEditor->setText(LLStringExplicit(buffer)); } previewEditor->makePristine(); diff --git a/linden/indra/newview/llpreviewnotecard.h b/linden/indra/newview/llpreviewnotecard.h index 6a52b1f..9909284 100644 --- a/linden/indra/newview/llpreviewnotecard.h +++ b/linden/indra/newview/llpreviewnotecard.h @@ -2,6 +2,8 @@ * @file llpreviewnotecard.h * @brief LLPreviewNotecard class header file * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPREVIEWNOTECARD_H diff --git a/linden/indra/newview/llpreviewscript.cpp b/linden/indra/newview/llpreviewscript.cpp index cce672b..7eac589 100644 --- a/linden/indra/newview/llpreviewscript.cpp +++ b/linden/indra/newview/llpreviewscript.cpp @@ -2,6 +2,8 @@ * @file llpreviewscript.cpp * @brief LLPreviewScript class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -100,11 +103,8 @@ const char HELLO_LSL[] = "}\n"; const char HELP_LSL[] = "lsl_guide.html"; -const char DEFAULT_SCRIPT_NAME[] = "New Script"; -const char DEFAULT_SCRIPT_DESC[] = "(No Description)"; - -const char ENABLED_RUNNING_CHECKBOX_LABEL[] = "Running"; -const char DISABLED_RUNNING_CHECKBOX_LABEL[] = "Public Objects cannot run scripts"; +const char DEFAULT_SCRIPT_NAME[] = "New Script"; // *TODO:Translate? +const char DEFAULT_SCRIPT_DESC[] = "(No Description)"; // *TODO:Translate? // Description and header information @@ -318,7 +318,6 @@ LLScriptEdCore::LLScriptEdCore( mFunctions = LLUICtrlFactory::getComboBoxByName(this, "Insert..."); childSetCommitCallback("Insert...", &LLScriptEdCore::onBtnInsertFunction, this); - mFunctions->setLabel("Insert..."); mEditor = LLViewerUICtrlFactory::getViewerTextEditorByName(this, "Script Editor"); mEditor->setReadOnlyBgColor(gColors.getColor( "ScriptBgReadOnlyColor" ) ); @@ -453,13 +452,13 @@ void LLScriptEdCore::draw() S32 line = 0; S32 column = 0; mEditor->getCurrentLineAndColumn( &line, &column, FALSE ); // don't include wordwrap - char cursor_pos[STD_STRING_BUF_SIZE]; /*Flawfinder: ignore*/ - snprintf( cursor_pos, STD_STRING_BUF_SIZE, "Line %d, Column %d", line, column ); /* Flawfinder: ignore */ + std::string cursor_pos; + cursor_pos = llformat("Line %d, Column %d", line, column ); childSetText("line_col", cursor_pos); } else { - childSetText("line_col", ""); + childSetText("line_col", LLString::null); } updateDynamicHelp(); @@ -982,7 +981,7 @@ void LLScriptEdCore::handleReloadFromServerDialog( S32 option, void* userdata ) case 0: // "Yes" if( self->mLoadCallback ) { - self->mEditor->setText( "Loading..." ); + self->mEditor->setText( self->childGetText("loading") ); self->mLoadCallback( self->mUserdata ); } break; @@ -1196,7 +1195,7 @@ void LLPreviewLSL::loadAsset() } else { - mScriptEd->mEditor->setText("You are not allowed to view this script."); + mScriptEd->mEditor->setText(mScriptEd->childGetText("can_not_view")); mScriptEd->mEditor->makePristine(); mScriptEd->mEditor->setEnabled(FALSE); mScriptEd->mFunctions->setEnabled(FALSE); @@ -1207,7 +1206,7 @@ void LLPreviewLSL::loadAsset() } else { - mScriptEd->mEditor->setText(HELLO_LSL); + mScriptEd->mEditor->setText(LLString(HELLO_LSL)); mAssetStatus = PREVIEW_ASSET_LOADED; } } @@ -1514,7 +1513,7 @@ void LLPreviewLSL::onLoadComplete( LLVFS *vfs, const LLUUID& asset_uuid, LLAsset // put a EOS at the end buffer[file_length] = 0; - preview->mScriptEd->mEditor->setText(buffer); + preview->mScriptEd->mEditor->setText(LLStringExplicit(buffer)); preview->mScriptEd->mEditor->makePristine(); delete [] buffer; LLInventoryItem* item = gInventory.getItem(*item_uuid); @@ -1663,7 +1662,6 @@ LLLiveLSLEditor::LLLiveLSLEditor(const std::string& name, setTitle(title); - } LLLiveLSLEditor::~LLLiveLSLEditor() @@ -1715,9 +1713,8 @@ void LLLiveLSLEditor::loadAsset(BOOL is_new) { // HACK! we "know" that mItemID refers to a LLViewerInventoryItem... LLViewerInventoryItem* item = (LLViewerInventoryItem*)object->getInventoryObject(mItemID); - if(item - && (gAgent.allowOperation(PERM_COPY, item->getPermissions(), - GP_OBJECT_MANIPULATE) + if(item + && (gAgent.allowOperation(PERM_COPY, item->getPermissions(), GP_OBJECT_MANIPULATE) || gAgent.isGodlike())) { mItem = new LLViewerInventoryItem(item); @@ -1726,13 +1723,11 @@ void LLLiveLSLEditor::loadAsset(BOOL is_new) if(!gAgent.isGodlike() && (item - && (!gAgent.allowOperation(PERM_COPY, item->getPermissions(), - GP_OBJECT_MANIPULATE) - || !gAgent.allowOperation(PERM_MODIFY, - item->getPermissions(), GP_OBJECT_MANIPULATE)))) - + && (!gAgent.allowOperation(PERM_COPY, item->getPermissions(), GP_OBJECT_MANIPULATE) + || !gAgent.allowOperation(PERM_MODIFY, item->getPermissions(), GP_OBJECT_MANIPULATE)))) { - mScriptEd->mEditor->setText("You are not allowed to view this script."); + mItem = new LLViewerInventoryItem(item); + mScriptEd->mEditor->setText(childGetText("not_allowed")); mScriptEd->mEditor->makePristine(); mScriptEd->mEditor->setEnabled(FALSE); mAssetStatus = PREVIEW_ASSET_LOADED; @@ -1763,7 +1758,7 @@ void LLLiveLSLEditor::loadAsset(BOOL is_new) } else { - mScriptEd->mEditor->setText(""); + mScriptEd->mEditor->setText(LLString::null); mScriptEd->mEditor->makePristine(); mAssetStatus = PREVIEW_ASSET_LOADED; } @@ -1789,11 +1784,25 @@ void LLLiveLSLEditor::loadAsset(BOOL is_new) gMessageSystem->sendReliable(host); */ } + + // Initialization of the asset failed. Probably the result + // of a bug somewhere else. Set up this editor in a no-go mode. + if(mItem.isNull()) + { + // Set the inventory item to an incomplete item. + // This may be better than having a accessible null pointer around, + // though this newly allocated object will most likely be replaced. + mItem = new LLViewerInventoryItem(); + mScriptEd->mEditor->setText(LLString::null); + mScriptEd->mEditor->makePristine(); + mScriptEd->mEditor->setEnabled(FALSE); + mAssetStatus = PREVIEW_ASSET_LOADED; + } } else { - mScriptEd->mEditor->setText(HELLO_LSL); - //mScriptEd->mEditor->setText(""); + mScriptEd->mEditor->setText(LLString(HELLO_LSL)); + //mScriptEd->mEditor->setText(LLString::null); //mScriptEd->mEditor->makePristine(); LLPermissions perm; perm.init(gAgent.getID(), gAgent.getID(), LLUUID::null, gAgent.getGroupID()); @@ -1880,7 +1889,7 @@ void LLLiveLSLEditor::loadScriptText(const char* filename) } buffer[nread] = '\0'; fclose(file); - mScriptEd->mEditor->setText(buffer); + mScriptEd->mEditor->setText(LLStringExplicit(buffer)); mScriptEd->mEditor->makePristine(); delete[] buffer; } @@ -1905,7 +1914,7 @@ void LLLiveLSLEditor::loadScriptText(LLVFS *vfs, const LLUUID &uuid, LLAssetType buffer[file_length] = '\0'; - mScriptEd->mEditor->setText(buffer); + mScriptEd->mEditor->setText(LLStringExplicit(buffer)); mScriptEd->mEditor->makePristine(); delete[] buffer; @@ -1972,12 +1981,12 @@ void LLLiveLSLEditor::draw() { if(object->permAnyOwner()) { - runningCheckbox->setLabel(ENABLED_RUNNING_CHECKBOX_LABEL); + runningCheckbox->setLabel(childGetText("script_running")); runningCheckbox->setEnabled(TRUE); } else { - runningCheckbox->setLabel(DISABLED_RUNNING_CHECKBOX_LABEL); + runningCheckbox->setLabel(childGetText("public_objects_can_not_run")); runningCheckbox->setEnabled(FALSE); // *FIX: Set it to false so that the ui is correct for // a box that is released to public. It could be @@ -2036,6 +2045,14 @@ void LLLiveLSLEditor::saveIfNeeded() return; } + if(mItem.isNull() || !mItem->isComplete()) + { + // $NOTE: While the error message may not be exactly correct, + // it's pretty close. + gViewerWindow->alertXml("SaveScriptFailObjectNotFound"); + return; + } + // get the latest info about it. We used to be losing the script // name on save, because the viewer object version of the item, // and the editor version would get out of synch. Here's a good @@ -2217,7 +2234,7 @@ void LLLiveLSLEditor::uploadAssetLegacy(const std::string& filename, // If we successfully saved it, then we should be able to check/uncheck the running box! LLCheckBoxCtrl* runningCheckbox = LLUICtrlFactory::getCheckBoxByName(this, "running"); - runningCheckbox->setLabel(ENABLED_RUNNING_CHECKBOX_LABEL); + runningCheckbox->setLabel(childGetText("script_running")); runningCheckbox->setEnabled(TRUE); } @@ -2299,6 +2316,11 @@ void LLLiveLSLEditor::onSaveBytecodeComplete(const LLUUID& asset_uuid, void* use delete data; } +void LLLiveLSLEditor::open() +{ + LLFloater::open(); /*Flawfinder: ignore*/ +} + BOOL LLLiveLSLEditor::canClose() { return (mScriptEd->canClose()); diff --git a/linden/indra/newview/llpreviewscript.h b/linden/indra/newview/llpreviewscript.h index 9cc0e46..3dfeb2c 100644 --- a/linden/indra/newview/llpreviewscript.h +++ b/linden/indra/newview/llpreviewscript.h @@ -2,6 +2,8 @@ * @file llpreviewscript.h * @brief LLPreviewScript class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPREVIEWSCRIPT_H @@ -213,6 +216,9 @@ public: bool is_script_running); virtual void callbackLSLCompileFailed(const LLSD& compile_errors); + // Overide LLPreview::open() to avoid calling loadAsset twice. + /*virtual*/ void open(); /*Flawfinder: ignore*/ + protected: virtual BOOL canClose(); void closeIfNeeded(); diff --git a/linden/indra/newview/llpreviewsound.cpp b/linden/indra/newview/llpreviewsound.cpp index 7c7afe6..fae0487 100644 --- a/linden/indra/newview/llpreviewsound.cpp +++ b/linden/indra/newview/llpreviewsound.cpp @@ -2,6 +2,8 @@ * @file llpreviewsound.cpp * @brief LLPreviewSound class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llpreviewsound.h b/linden/indra/newview/llpreviewsound.h index 38b34d0..74df017 100644 --- a/linden/indra/newview/llpreviewsound.h +++ b/linden/indra/newview/llpreviewsound.h @@ -2,6 +2,8 @@ * @file llpreviewsound.h * @brief LLPreviewSound class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPREVIEWSOUND_H diff --git a/linden/indra/newview/llpreviewtexture.cpp b/linden/indra/newview/llpreviewtexture.cpp index 5cba31d..4c8d4ef 100644 --- a/linden/indra/newview/llpreviewtexture.cpp +++ b/linden/indra/newview/llpreviewtexture.cpp @@ -2,6 +2,8 @@ * @file llpreviewtexture.cpp * @brief LLPreviewTexture class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llpreviewtexture.h b/linden/indra/newview/llpreviewtexture.h index 4749dc2..b7850de 100644 --- a/linden/indra/newview/llpreviewtexture.h +++ b/linden/indra/newview/llpreviewtexture.h @@ -2,6 +2,8 @@ * @file llpreviewtexture.h * @brief LLPreviewTexture class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPREVIEWTEXTURE_H diff --git a/linden/indra/newview/llprogressview.cpp b/linden/indra/newview/llprogressview.cpp index 2ec8dcd..d855f75 100644 --- a/linden/indra/newview/llprogressview.cpp +++ b/linden/indra/newview/llprogressview.cpp @@ -2,6 +2,8 @@ * @file llprogressview.cpp * @brief LLProgressView class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llprogressview.h b/linden/indra/newview/llprogressview.h index ae0ae72..b284e20 100644 --- a/linden/indra/newview/llprogressview.h +++ b/linden/indra/newview/llprogressview.h @@ -2,6 +2,8 @@ * @file llprogressview.h * @brief LLProgressView class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLPROGRESSVIEW_H diff --git a/linden/indra/newview/llregionposition.cpp b/linden/indra/newview/llregionposition.cpp index dff6d72..e900bd0 100644 --- a/linden/indra/newview/llregionposition.cpp +++ b/linden/indra/newview/llregionposition.cpp @@ -2,6 +2,8 @@ * @file llregionposition.cpp * @brief Region position storing class definition * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llregionposition.h b/linden/indra/newview/llregionposition.h index bbe8472..bdeb3ee 100644 --- a/linden/indra/newview/llregionposition.h +++ b/linden/indra/newview/llregionposition.h @@ -2,6 +2,8 @@ * @file llregionposition.h * @brief Region position storing class definition * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLREGIONPOSITION_H diff --git a/linden/indra/newview/llresourcedata.h b/linden/indra/newview/llresourcedata.h index 9f5d329..dbff01e 100644 --- a/linden/indra/newview/llresourcedata.h +++ b/linden/indra/newview/llresourcedata.h @@ -2,6 +2,8 @@ * @file llresourcedata.h * @brief Tracking object for uploads. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLRESOURCEDATA_H diff --git a/linden/indra/newview/llroam.cpp b/linden/indra/newview/llroam.cpp index 8f45c79..9725cde 100644 --- a/linden/indra/newview/llroam.cpp +++ b/linden/indra/newview/llroam.cpp @@ -2,6 +2,8 @@ * @file llroam.cpp * @brief LLRoam and related class implementations * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llroam.h b/linden/indra/newview/llroam.h index 758df0e..82110ae 100644 --- a/linden/indra/newview/llroam.h +++ b/linden/indra/newview/llroam.h @@ -2,6 +2,8 @@ * @file llroam.h * @brief LLRoam and related class definitions * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /****************************************/ diff --git a/linden/indra/newview/llsavedsettingsglue.cpp b/linden/indra/newview/llsavedsettingsglue.cpp index 6b42c73..d944b4a 100644 --- a/linden/indra/newview/llsavedsettingsglue.cpp +++ b/linden/indra/newview/llsavedsettingsglue.cpp @@ -3,6 +3,8 @@ * @author James Cook * @brief LLSavedSettingsGlue class implementation * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llsavedsettingsglue.h b/linden/indra/newview/llsavedsettingsglue.h index 398cac0..3a848b3 100644 --- a/linden/indra/newview/llsavedsettingsglue.h +++ b/linden/indra/newview/llsavedsettingsglue.h @@ -3,6 +3,8 @@ * @author James Cook * @brief LLSavedSettingsGlue class definition * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSAVEDSETTINGSGLUE_H diff --git a/linden/indra/newview/llselectmgr.cpp b/linden/indra/newview/llselectmgr.cpp index ec01d54..128a802 100644 --- a/linden/indra/newview/llselectmgr.cpp +++ b/linden/indra/newview/llselectmgr.cpp @@ -2,6 +2,8 @@ * @file llselectmgr.cpp * @brief A manager for selected objects and faces. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -210,6 +213,11 @@ LLSelectMgr::LLSelectMgr() //----------------------------------------------------------------------------- LLSelectMgr::~LLSelectMgr() { + clearSelections(); +} + +void LLSelectMgr::clearSelections() +{ mHoverObjects->deleteAllNodes(); mSelectedObjects->deleteAllNodes(); mHighlightedObjects->deleteAllNodes(); @@ -217,21 +225,27 @@ LLSelectMgr::~LLSelectMgr() mGridObjects.deleteAllNodes(); } -void LLSelectMgr::updateEffects() +void LLSelectMgr::update() { + mSelectedObjects->cleanupNodes(); +} +void LLSelectMgr::updateEffects() +{ //keep reference grid objects active - for (LLSelectNode* grid_nodep = mGridObjects.getFirstNode(); - grid_nodep; - grid_nodep = mGridObjects.getNextNode()) + struct f : public LLSelectedObjectFunctor { - LLViewerObject* grid_object = grid_nodep->getObject(); - LLDrawable* drawable = grid_object->mDrawable; - if (drawable) + virtual bool apply(LLViewerObject* object) { - gPipeline.markMoved(drawable); + LLDrawable* drawable = object->mDrawable; + if (drawable) + { + gPipeline.markMoved(drawable); + } + return true; } - } + } func; + mGridObjects.applyToObjects(&func); if (mEffectsTimer.getElapsedTimeF32() > 1.f) { @@ -243,29 +257,30 @@ void LLSelectMgr::updateEffects() void LLSelectMgr::overrideObjectUpdates() { //override any position updates from simulator on objects being edited - LLSelectNode* selectNode; - for (selectNode = gSelectMgr->getSelection()->getFirstNode(); - selectNode != NULL; - selectNode = gSelectMgr->getSelection()->getNextNode()) + struct f : public LLSelectedNodeFunctor { - LLViewerObject* object = selectNode->getObject(); - - if (object->permMove()) + virtual bool apply(LLSelectNode* selectNode) { - if (!selectNode->mLastPositionLocal.isExactlyZero()) - { - object->setPosition(selectNode->mLastPositionLocal); - } - if (selectNode->mLastRotation != LLQuaternion()) - { - object->setRotation(selectNode->mLastRotation); - } - if (!selectNode->mLastScale.isExactlyZero()) + LLViewerObject* object = selectNode->getObject(); + if (object->permMove()) { - object->setScale(selectNode->mLastScale); + if (!selectNode->mLastPositionLocal.isExactlyZero()) + { + object->setPosition(selectNode->mLastPositionLocal); + } + if (selectNode->mLastRotation != LLQuaternion()) + { + object->setRotation(selectNode->mLastRotation); + } + if (!selectNode->mLastScale.isExactlyZero()) + { + object->setScale(selectNode->mLastScale); + } } + return true; } - } + } func; + getSelection()->applyToNodes(&func); } //----------------------------------------------------------------------------- @@ -414,24 +429,26 @@ LLObjectSelectionHandle LLSelectMgr::selectObjectAndFamily(LLViewerObject* obj, //----------------------------------------------------------------------------- // Select the object, parents and children. //----------------------------------------------------------------------------- -LLObjectSelectionHandle LLSelectMgr::selectObjectAndFamily(const LLDynamicArray& object_list, - BOOL send_to_sim) +LLObjectSelectionHandle LLSelectMgr::selectObjectAndFamily(const std::vector& object_list, + BOOL send_to_sim) { // Collect all of the objects, children included LLDynamicArray objects; - LLViewerObject *object; - S32 i; //clear primary object (no primary object) mSelectedObjects->mPrimaryObject = NULL; - if (object_list.count() < 1) return NULL; - + if (object_list.size() < 1) + { + return NULL; + } + // NOTE -- we add the objects in REVERSE ORDER // to preserve the order in the mSelectedObjects list - for (i = object_list.count() - 1; i >= 0; i--) + for (std::vector::const_reverse_iterator riter = object_list.rbegin(); + riter != object_list.rend(); ++riter) { - object = object_list.get(i); + LLViewerObject *object = *riter; llassert( object ); @@ -503,44 +520,30 @@ BOOL LLSelectMgr::removeObjectFromSelections(const LLUUID &id) // Iterate through selected objects list and kill the object if( !object_found ) { - LLViewerObject* prevobjp = NULL; - for( LLViewerObject* tobjp = mSelectedObjects->getFirstObject(); tobjp != NULL; tobjp = mSelectedObjects->getNextObject() ) + for (LLObjectSelection::iterator iter = getSelection()->begin(); + iter != getSelection()->end(); ) { - if (tobjp == prevobjp) - { - // Somehow we got stuck in an infinite loop... (DaveP) - // this logic is kind of twisted, not sure how this is happening, so... - llwarns << "Detected infinite loop #1 in LLSelectMgr::removeObjectFromSelections:|" << llendl; - //MikeS. adding warning and comment... - //These infinite loops happen because the LLSelectMgr iteration routines are non-reentrant. - //deselectObjectAndFamily uses getFirstObject and getNextObject to mess with the array, - //resetting the arrays internal iterator state. This needs fixing BAD. - continue; - } - // It's possible the item being removed has an avatar sitting on it - // So remove the avatar that is sitting on the object. - if (tobjp->mID == id || tobjp->isAvatar()) + LLObjectSelection::iterator curiter = iter++; + LLViewerObject* object = (*curiter)->getObject(); + if (object->mID == id) { - if (!gNoRender) + if (tool) { tool->stopEditing(); } // lose the selection, don't tell simulator, it knows - deselectObjectAndFamily(tobjp, FALSE); - - if (tobjp->mID == id) - { - if(object_found == TRUE){ - //MikeS. adding warning... This happens when removing a linked attachment while sitting on an object.. - //I think the selection manager needs to be rewritten. BAD. - llwarns << "Detected infinite loop #2 in LLSelectMgr::removeObjectFromSelections:|" << llendl; - break; - } - object_found = TRUE; - } + deselectObjectAndFamily(object, FALSE); + object_found = TRUE; + break; // must break here, may have removed multiple objects from list + } + else if (object->isAvatar()) + { + // It's possible the item being removed has an avatar sitting on it + // So remove the avatar that is sitting on the object. + deselectObjectAndFamily(object, FALSE); + break; // must break here, may have removed multiple objects from list } - prevobjp = tobjp; } } @@ -593,7 +596,7 @@ void LLSelectMgr::deselectObjectAndFamily(LLViewerObject* object, BOOL send_to_s S32 select_count = 0; LLMessageSystem* msg = gMessageSystem; - for (S32 i = 0; i < objects.count(); i++) + for (U32 i = 0; i < objects.size(); i++) { if (start_new_message) { @@ -656,15 +659,12 @@ void LLSelectMgr::deselectObjectOnly(LLViewerObject* object, BOOL send_to_sim) // addAsFamily //----------------------------------------------------------------------------- -void LLSelectMgr::addAsFamily(LLDynamicArray& objects, BOOL add_to_end) +void LLSelectMgr::addAsFamily(std::vector& objects, BOOL add_to_end) { - S32 count = objects.count(); - LLViewerObject *objectp = NULL; - - LLSelectNode *nodep = NULL; - for (S32 i = 0; i < count; i++) + for (std::vector::iterator iter = objects.begin(); + iter != objects.end(); ++iter) { - objectp = objects.get(i); + LLViewerObject* objectp = *iter; // Can't select yourself if (objectp->mID == gAgentID @@ -675,7 +675,7 @@ void LLSelectMgr::addAsFamily(LLDynamicArray& objects, BOOL add if (!objectp->isSelected()) { - nodep = new LLSelectNode(objectp, TRUE); + LLSelectNode *nodep = new LLSelectNode(objectp, TRUE); if (add_to_end) { mSelectedObjects->addNodeAtEnd(nodep); @@ -722,14 +722,14 @@ void LLSelectMgr::addAsIndividual(LLViewerObject *objectp, S32 face, BOOL undoab { nodep = new LLSelectNode(objectp, TRUE); mSelectedObjects->addNode(nodep); + llassert_always(nodep->getObject()); } else { // make this a full-fledged selection nodep->setTransient(FALSE); // Move it to the front of the list - mSelectedObjects->removeNode(nodep); - mSelectedObjects->addNode(nodep); + mSelectedObjects->moveNodeToFront(nodep); } // Make sure the object is tagged as selected @@ -790,14 +790,11 @@ LLObjectSelectionHandle LLSelectMgr::setHoverObject(LLViewerObject *objectp) objectp = objectp->getRootEdit(); objectp->addThisAndNonJointChildren(objects); - - S32 count = objects.count(); - LLViewerObject* cur_objectp = NULL; - LLSelectNode* nodep = NULL; - for(S32 i = 0; i < count; i++) + for (std::vector::iterator iter = objects.begin(); + iter != objects.end(); ++iter) { - cur_objectp = objects[i]; - nodep = new LLSelectNode(cur_objectp, FALSE); + LLViewerObject* cur_objectp = *iter; + LLSelectNode* nodep = new LLSelectNode(cur_objectp, FALSE); mHoverObjects->addNodeAtEnd(nodep); } @@ -850,28 +847,30 @@ void LLSelectMgr::highlightObjectAndFamily(LLViewerObject* objectp) } // Note that this ignores the "select owned only" flag -// It's also more efficient than calling the single-object version over and -// over. -void LLSelectMgr::highlightObjectAndFamily(const LLDynamicArray& list) +// It's also more efficient than calling the single-object version over and over. +void LLSelectMgr::highlightObjectAndFamily(const std::vector& objects) { - S32 i; - S32 count = list.count(); - - for (i = 0; i < count; i++) + for (std::vector::const_iterator iter1 = objects.begin(); + iter1 != objects.end(); ++iter1) { - LLViewerObject* object = list.get(i); + LLViewerObject* object = *iter1; - if (!object) continue; - if (object->getPCode() != LL_PCODE_VOLUME) continue; + if (!object) + { + continue; + } + if (object->getPCode() != LL_PCODE_VOLUME) + { + continue; + } LLViewerObject* root = (LLViewerObject*)object->getRoot(); mRectSelectedObjects.insert(root); - S32 j; - S32 child_count = root->mChildList.size(); - for (j = 0; j < child_count; j++) + for (LLViewerObject::child_list_t::const_iterator iter2 = root->mChildList.begin(); + iter2 != root->mChildList.end(); ++iter2) { - LLViewerObject* child = root->mChildList[j]; + LLViewerObject* child = *iter2; mRectSelectedObjects.insert(child); } } @@ -898,9 +897,11 @@ void LLSelectMgr::unhighlightObjectAndFamily(LLViewerObject* objectp) unhighlightObjectOnly(root_obj); - for(U32 i = 0; i < root_obj->mChildList.size(); i++) + for (LLViewerObject::child_list_t::iterator iter2 = root_obj->mChildList.begin(); + iter2 != root_obj->mChildList.end(); ++iter2) { - unhighlightObjectOnly(root_obj->mChildList[i]); + LLViewerObject* child = *iter2; + unhighlightObjectOnly(child); } } @@ -921,11 +922,12 @@ LLObjectSelectionHandle LLSelectMgr::selectHighlightedObjects() //clear primary object mSelectedObjects->mPrimaryObject = NULL; - LLSelectNode *nodep; - for (nodep = mHighlightedObjects->getFirstNode(); - nodep; - nodep = mHighlightedObjects->getNextNode()) + for (LLObjectSelection::iterator iter = getHighlightedObjects()->begin(); + iter != getHighlightedObjects()->end(); ) { + LLObjectSelection::iterator curiter = iter++; + + LLSelectNode *nodep = *curiter; LLViewerObject* objectp = nodep->getObject(); if (!canSelectObject(objectp)) @@ -997,9 +999,12 @@ void LLSelectMgr::addGridObject(LLViewerObject* objectp) { LLSelectNode* nodep = new LLSelectNode(objectp, FALSE); mGridObjects.addNodeAtEnd(nodep); - for (U32 i = 0; i < objectp->mChildList.size(); i++) + + for (LLViewerObject::child_list_t::iterator iter2 = objectp->mChildList.begin(); + iter2 != objectp->mChildList.end(); ++iter2) { - nodep = new LLSelectNode(objectp->mChildList[i], FALSE); + LLViewerObject* child = *iter2; + nodep = new LLSelectNode(child, FALSE); mGridObjects.addNodeAtEnd(nodep); } } @@ -1019,14 +1024,9 @@ void LLSelectMgr::setGridMode(EGridMode mode) void LLSelectMgr::getGrid(LLVector3& origin, LLQuaternion &rotation, LLVector3 &scale) { - LLSelectNode* grid_node = mGridObjects.getFirstNode(); - LLViewerObject* grid_object = mGridObjects.getFirstObject(); - // *TODO: get to work with multiple grid objects - if (grid_node && grid_node->getObject()->isDead()) - { - mGridObjects.removeNode(grid_node); - grid_object = NULL; - } + mGridObjects.cleanupNodes(); + + LLViewerObject* first_grid_object = mGridObjects.getFirstObject(); if (mGridMode == GRID_MODE_LOCAL && mSelectedObjects->getObjectCount()) { @@ -1035,47 +1035,42 @@ void LLSelectMgr::getGrid(LLVector3& origin, LLQuaternion &rotation, LLVector3 & mGridRotation = mSavedSelectionBBox.getRotation(); mGridScale = mSavedSelectionBBox.getExtentLocal() * 0.5f; } - else if (mGridMode == GRID_MODE_REF_OBJECT && grid_object && grid_object->mDrawable.notNull()) + else if (mGridMode == GRID_MODE_REF_OBJECT && first_grid_object && first_grid_object->mDrawable.notNull()) { - mGridRotation = grid_object->getRenderRotation(); - LLVector3 first_grid_obj_pos = grid_object->getRenderPosition(); + mGridRotation = first_grid_object->getRenderRotation(); + LLVector3 first_grid_obj_pos = first_grid_object->getRenderPosition(); LLVector3 min_extents(F32_MAX, F32_MAX, F32_MAX); - LLVector3 max_extents(-min_extents); + LLVector3 max_extents(-F32_MAX, -F32_MAX, -F32_MAX); BOOL grid_changed = FALSE; - LLSelectNode* grid_nodep; - for (grid_nodep = mGridObjects.getFirstNode(); - grid_nodep; - grid_nodep = mGridObjects.getNextNode()) + for (LLObjectSelection::iterator iter = mGridObjects.begin(); + iter != mGridObjects.end(); ++iter) + { + LLViewerObject* object = (*iter)->getObject(); + LLDrawable* drawable = object->mDrawable; + if (drawable) { - grid_object = grid_nodep->getObject(); - LLDrawable* drawable = grid_object->mDrawable; - if (drawable) - { - const LLVector3* ext = drawable->getSpatialExtents(); - update_min_max(min_extents, max_extents, ext[0]); - update_min_max(min_extents, max_extents, ext[1]); - grid_changed = TRUE; - } + const LLVector3* ext = drawable->getSpatialExtents(); + update_min_max(min_extents, max_extents, ext[0]); + update_min_max(min_extents, max_extents, ext[1]); + grid_changed = TRUE; } + } if (grid_changed) { mGridOrigin = lerp(min_extents, max_extents, 0.5f); - LLDrawable* drawable = grid_object->mDrawable; + LLDrawable* drawable = first_grid_object->mDrawable; if (drawable && drawable->isActive()) { - mGridOrigin = mGridOrigin * grid_object->getRenderMatrix(); + mGridOrigin = mGridOrigin * first_grid_object->getRenderMatrix(); } mGridScale = (max_extents - min_extents) * 0.5f; } } else // GRID_MODE_WORLD or just plain default { - LLViewerObject* first_object = mSelectedObjects->getFirstRootObject(); - if (!first_object) - { - first_object = mSelectedObjects->getFirstObject(); - } + const BOOL non_root_ok = TRUE; + LLViewerObject* first_object = mSelectedObjects->getFirstRootObject(non_root_ok); mGridOrigin.clearVec(); mGridRotation.loadIdentity(); @@ -1115,26 +1110,20 @@ void LLSelectMgr::getGrid(LLVector3& origin, LLQuaternion &rotation, LLVector3 & // remove() - an array of objects //----------------------------------------------------------------------------- -void LLSelectMgr::remove(LLDynamicArray& objects) +void LLSelectMgr::remove(std::vector& objects) { - S32 count = objects.count(); - LLViewerObject *objectp = NULL; - LLSelectNode *nodep = NULL; - for(S32 i = 0; i < count; i++) + for (std::vector::iterator iter = objects.begin(); + iter != objects.end(); ++iter) { - objectp = objects.get(i); - for(nodep = mSelectedObjects->getFirstNode(); - nodep != NULL; - nodep = mSelectedObjects->getNextNode()) + LLViewerObject* objectp = *iter; + LLSelectNode* nodep = mSelectedObjects->findNode(objectp); + if (nodep) { - if(nodep->getObject() == objectp) - { - objectp->setSelected(FALSE); - mSelectedObjects->removeNode(nodep); - break; - } + objectp->setSelected(FALSE); + mSelectedObjects->removeNode(nodep); + nodep = NULL; } - } + } updateSelectionCenter(); dialog_refresh_all(); } @@ -1145,26 +1134,19 @@ void LLSelectMgr::remove(LLDynamicArray& objects) //----------------------------------------------------------------------------- void LLSelectMgr::remove(LLViewerObject *objectp, S32 te, BOOL undoable) { - // check if object already in list - // *FIX: can we just check isSelected()? + // get object node (and verify it is in the selected list) LLSelectNode *nodep = mSelectedObjects->findNode(objectp); - if (!nodep) { return; } - // if face = all, remove object from list - if (objectp->getNumTEs() <= 0) - { - // object doesn't have faces, so blow it away - mSelectedObjects->removeNode(nodep); - objectp->setSelected( FALSE ); - } - else if (te == SELECT_ALL_TES) + if ((objectp->getNumTEs() <= 0) || (te == SELECT_ALL_TES)) { + // Remove all faces (or the object doesn't have faces) so remove the node mSelectedObjects->removeNode(nodep); + nodep = NULL; objectp->setSelected( FALSE ); } else if (0 <= te && te < SELECT_MAX_TES) @@ -1191,9 +1173,9 @@ void LLSelectMgr::remove(LLViewerObject *objectp, S32 te, BOOL undoable) if (!found) { mSelectedObjects->removeNode(nodep); + nodep = NULL; objectp->setSelected( FALSE ); - - // BUG: Doesn't update simulator that object is gone. + // *FIXME: Doesn't update simulator that object is no longer selected } } else @@ -1212,14 +1194,15 @@ void LLSelectMgr::remove(LLViewerObject *objectp, S32 te, BOOL undoable) //----------------------------------------------------------------------------- void LLSelectMgr::removeAll() { - LLViewerObject *objectp; - for (objectp = mSelectedObjects->getFirstObject(); objectp; objectp = mSelectedObjects->getNextObject() ) + for (LLObjectSelection::iterator iter = mSelectedObjects->begin(); + iter != mSelectedObjects->end(); iter++ ) { + LLViewerObject *objectp = (*iter)->getObject(); objectp->setSelected( FALSE ); } mSelectedObjects->deleteAllNodes(); - + updateSelectionCenter(); dialog_refresh_all(); } @@ -1233,19 +1216,19 @@ void LLSelectMgr::promoteSelectionToRoot() BOOL selection_changed = FALSE; - LLSelectNode* nodep; - LLViewerObject *objectp; - for (nodep = mSelectedObjects->getFirstNode(); - nodep; - nodep = mSelectedObjects->getNextNode() ) + for (LLObjectSelection::iterator iter = getSelection()->begin(); + iter != getSelection()->end(); ) { + LLObjectSelection::iterator curiter = iter++; + LLSelectNode* nodep = *curiter; + LLViewerObject* object = nodep->getObject(); + if (nodep->mIndividualSelection) { selection_changed = TRUE; } - objectp = nodep->getObject(); - LLViewerObject* parentp = objectp; + LLViewerObject* parentp = object; while(parentp->getParent() && !(parentp->isRootEdit() || parentp->isJointChild())) { parentp = (LLViewerObject*)parentp->getParent(); @@ -1273,19 +1256,21 @@ void LLSelectMgr::demoteSelectionToIndividuals() { LLDynamicArray objects; - for (LLViewerObject* root_objectp = mSelectedObjects->getFirstRootObject(); - root_objectp; - root_objectp = mSelectedObjects->getNextRootObject()) + for (LLObjectSelection::root_iterator iter = getSelection()->root_begin(); + iter != getSelection()->root_end(); iter++) { - root_objectp->addThisAndNonJointChildren(objects); + LLViewerObject* object = (*iter)->getObject(); + object->addThisAndNonJointChildren(objects); } if (objects.getLength()) { deselectAll(); - for(S32 i = 0; i < objects.count(); i++) + for (std::vector::iterator iter = objects.begin(); + iter != objects.end(); ++iter) { - selectObjectOnly(objects[i]); + LLViewerObject* objectp = *iter; + selectObjectOnly(objectp); } } } @@ -1299,14 +1284,12 @@ void LLSelectMgr::dump() llinfos << "TE mode " << mTEMode << llendl; - S32 i = 0; - - LLViewerObject *objectp; - for (objectp = mSelectedObjects->getFirstObject(); - objectp; - objectp = mSelectedObjects->getNextObject()) + S32 count = 0; + for (LLObjectSelection::iterator iter = getSelection()->begin(); + iter != getSelection()->end(); iter++ ) { - llinfos << "Object " << i << " type " << LLPrimitive::pCodeToString(objectp->getPCode()) << llendl; + LLViewerObject* objectp = (*iter)->getObject(); + llinfos << "Object " << count << " type " << LLPrimitive::pCodeToString(objectp->getPCode()) << llendl; llinfos << " hasLSL " << objectp->flagScripted() << llendl; llinfos << " hasTouch " << objectp->flagHandleTouch() << llendl; llinfos << " hasMoney " << objectp->flagTakesMoney() << llendl; @@ -1317,16 +1300,22 @@ void LLSelectMgr::dump() LLDrawable* drawablep = objectp->mDrawable; llinfos << " " << (drawablep&& drawablep->isVisible() ? "visible" : "invisible") << llendl; llinfos << " " << (drawablep&& drawablep->isState(LLDrawable::FORCE_INVISIBLE) ? "force_invisible" : "") << llendl; - i++; + count++; } // Face iterator - S32 te; - for (mSelectedObjects->getFirstTE(&objectp, &te); - objectp; - mSelectedObjects->getNextTE(&objectp, &te)) + for (LLObjectSelection::iterator iter = getSelection()->begin(); + iter != getSelection()->end(); iter++ ) { - llinfos << "Object " << objectp << " te " << te << llendl; + LLSelectNode* node = *iter; + LLViewerObject* objectp = node->getObject(); + for (S32 te = 0; te < objectp->getNumTEs(); ++te ) + { + if (node->isTESelected(te)) + { + llinfos << "Object " << objectp << " te " << te << llendl; + } + } } llinfos << mHighlightedObjects->getNumNodes() << " objects currently highlighted." << llendl; @@ -1347,6 +1336,18 @@ void LLSelectMgr::cleanup() // Manipulate properties of selected objects //--------------------------------------------------------------------------- +struct LLSelectMgrSendFunctor : public LLSelectedObjectFunctor +{ + virtual bool apply(LLViewerObject* object) + { + if (object->permModify()) + { + object->sendTEUpdate(); + } + return true; + } +}; + //----------------------------------------------------------------------------- // selectionSetImage() //----------------------------------------------------------------------------- @@ -1355,7 +1356,6 @@ void LLSelectMgr::selectionSetImage(const LLUUID& imageid) { // First for (no copy) textures and multiple object selection LLViewerInventoryItem* item = gInventory.getItem(imageid); - if(item && !item->getPermissions().allowOperationBy(PERM_COPY, gAgent.getID()) && (mSelectedObjects->getNumNodes() > 1) ) @@ -1365,54 +1365,63 @@ void LLSelectMgr::selectionSetImage(const LLUUID& imageid) return; } - LLViewerObject* objectp; - S32 te; - - for (mSelectedObjects->getFirstTE(&objectp, &te); objectp; mSelectedObjects->getNextTE(&objectp, &te)) + struct f : public LLSelectedTEFunctor { - if (item) + LLViewerInventoryItem* mItem; + LLUUID mImageID; + f(LLViewerInventoryItem* item, const LLUUID& id) : mItem(item), mImageID(id) {} + bool apply(LLViewerObject* objectp, S32 te) { - if (te == -1) // all faces + if (mItem) { - LLToolDragAndDrop::dropTextureAllFaces(objectp, - item, - LLToolDragAndDrop::SOURCE_AGENT, - LLUUID::null); + if (te == -1) // all faces + { + LLToolDragAndDrop::dropTextureAllFaces(objectp, + mItem, + LLToolDragAndDrop::SOURCE_AGENT, + LLUUID::null); + } + else // one face + { + LLToolDragAndDrop::dropTextureOneFace(objectp, + te, + mItem, + LLToolDragAndDrop::SOURCE_AGENT, + LLUUID::null); + } } - else // one face + else // not an inventory item { - LLToolDragAndDrop::dropTextureOneFace(objectp, - te, - item, - LLToolDragAndDrop::SOURCE_AGENT, - LLUUID::null); + // Texture picker defaults aren't inventory items + // * Don't need to worry about permissions for them + // * Can just apply the texture and be done with it. + objectp->setTEImage(te, gImageList.getImage(mImageID, TRUE, FALSE)); } + return true; } - - else // not an inventory item - { - // Texture picker defaults aren't inventory items - // * Don't need to worry about permissions for them - // * Can just apply the texture and be done with it. - objectp->setTEImage(te, gImageList.getImage(imageid)); - - objectp->sendTEUpdate(); - } - } + } setfunc(item, imageid); + getSelection()->applyToTEs(&setfunc); - - // 1 particle effect per object - if (mSelectedObjects->mSelectType != SELECT_TYPE_HUD) + struct g : public LLSelectedObjectFunctor { - for (objectp = mSelectedObjects->getFirstObject(); objectp; objectp = mSelectedObjects->getNextObject()) + LLViewerInventoryItem* mItem; + g(LLViewerInventoryItem* item) : mItem(item) {} + virtual bool apply(LLViewerObject* object) { - LLHUDEffectSpiral *effectp = (LLHUDEffectSpiral *)gHUDManager->createViewerEffect(LLHUDObject::LL_HUD_EFFECT_BEAM, TRUE); - effectp->setSourceObject(gAgent.getAvatarObject()); - effectp->setTargetObject(objectp); - effectp->setDuration(LL_HUD_DUR_SHORT); - effectp->setColor(LLColor4U(gAgent.getEffectColor())); + if (!mItem) + { + object->sendTEUpdate(); + // 1 particle effect per object + LLHUDEffectSpiral *effectp = (LLHUDEffectSpiral *)gHUDManager->createViewerEffect(LLHUDObject::LL_HUD_EFFECT_BEAM, TRUE); + effectp->setSourceObject(gAgent.getAvatarObject()); + effectp->setTargetObject(object); + effectp->setDuration(LL_HUD_DUR_SHORT); + effectp->setColor(LLColor4U(gAgent.getEffectColor())); + } + return true; } - } + } sendfunc(item); + getSelection()->applyToObjects(&sendfunc); } //----------------------------------------------------------------------------- @@ -1420,24 +1429,23 @@ void LLSelectMgr::selectionSetImage(const LLUUID& imageid) //----------------------------------------------------------------------------- void LLSelectMgr::selectionSetColor(const LLColor4 &color) { - LLViewerObject* object; - S32 te; - for (mSelectedObjects->getFirstTE(&object, &te); object; mSelectedObjects->getNextTE(&object, &te) ) - { - if (object->permModify()) - { - // update viewer side color in anticipation of update from simulator - object->setTEColor(te, color); - } - } - - for ( object = mSelectedObjects->getFirstObject(); object; object = mSelectedObjects->getNextObject() ) + struct f : public LLSelectedTEFunctor { - if (object->permModify()) + LLColor4 mColor; + f(const LLColor4& c) : mColor(c) {} + bool apply(LLViewerObject* object, S32 te) { - object->sendTEUpdate(); + if (object->permModify()) + { + object->setTEColor(te, mColor); + } + return true; } - } + } setfunc(color); + getSelection()->applyToTEs(&setfunc); + + LLSelectMgrSendFunctor sendfunc; + getSelection()->applyToObjects(&sendfunc); } //----------------------------------------------------------------------------- @@ -1445,27 +1453,26 @@ void LLSelectMgr::selectionSetColor(const LLColor4 &color) //----------------------------------------------------------------------------- void LLSelectMgr::selectionSetColorOnly(const LLColor4 &color) { - LLViewerObject* object; - LLColor4 new_color = color; - S32 te; - for (mSelectedObjects->getFirstTE(&object, &te); object; mSelectedObjects->getNextTE(&object, &te) ) - { - if (object->permModify()) - { - LLColor4 prev_color = object->getTE(te)->getColor(); - new_color.mV[VALPHA] = prev_color.mV[VALPHA]; - // update viewer side color in anticipation of update from simulator - object->setTEColor(te, new_color); - } - } - - for ( object = mSelectedObjects->getFirstObject(); object; object = mSelectedObjects->getNextObject() ) + struct f : public LLSelectedTEFunctor { - if (object->permModify()) + LLColor4 mColor; + f(const LLColor4& c) : mColor(c) {} + bool apply(LLViewerObject* object, S32 te) { - object->sendTEUpdate(); + if (object->permModify()) + { + LLColor4 prev_color = object->getTE(te)->getColor(); + mColor.mV[VALPHA] = prev_color.mV[VALPHA]; + // update viewer side color in anticipation of update from simulator + object->setTEColor(te, mColor); + } + return true; } - } + } setfunc(color); + getSelection()->applyToTEs(&setfunc); + + LLSelectMgrSendFunctor sendfunc; + getSelection()->applyToObjects(&sendfunc); } //----------------------------------------------------------------------------- @@ -1473,227 +1480,246 @@ void LLSelectMgr::selectionSetColorOnly(const LLColor4 &color) //----------------------------------------------------------------------------- void LLSelectMgr::selectionSetAlphaOnly(const F32 alpha) { - LLViewerObject* object; - S32 te; - for (mSelectedObjects->getFirstTE(&object, &te); object; mSelectedObjects->getNextTE(&object, &te) ) - { - if (object->permModify()) - { - LLColor4 prev_color = object->getTE(te)->getColor(); - prev_color.mV[VALPHA] = alpha; - // update viewer side color in anticipation of update from simulator - object->setTEColor(te, prev_color); - } - } - - for ( object = mSelectedObjects->getFirstObject(); object; object = mSelectedObjects->getNextObject() ) + struct f : public LLSelectedTEFunctor { - if (object->permModify()) + F32 mAlpha; + f(const F32& a) : mAlpha(a) {} + bool apply(LLViewerObject* object, S32 te) { - object->sendTEUpdate(); + if (object->permModify()) + { + LLColor4 prev_color = object->getTE(te)->getColor(); + prev_color.mV[VALPHA] = mAlpha; + // update viewer side color in anticipation of update from simulator + object->setTEColor(te, prev_color); + } + return true; } - } + } setfunc(alpha); + getSelection()->applyToTEs(&setfunc); + + LLSelectMgrSendFunctor sendfunc; + getSelection()->applyToObjects(&sendfunc); } void LLSelectMgr::selectionRevertColors() { - LLViewerObject* object; - S32 te; - - for (mSelectedObjects->getFirstTE(&object, &te); object; mSelectedObjects->getNextTE(&object, &te) ) + struct f : public LLSelectedTEFunctor { - if (object->permModify()) + LLObjectSelectionHandle mSelectedObjects; + f(LLObjectSelectionHandle sel) : mSelectedObjects(sel) {} + bool apply(LLViewerObject* object, S32 te) { - LLSelectNode* nodep = mSelectedObjects->findNode(object); - if (nodep && te < (S32)nodep->mSavedColors.size()) + if (object->permModify()) { - LLColor4 color = nodep->mSavedColors[te]; - // update viewer side color in anticipation of update from simulator - object->setTEColor(te, color); + LLSelectNode* nodep = mSelectedObjects->findNode(object); + if (nodep && te < (S32)nodep->mSavedColors.size()) + { + LLColor4 color = nodep->mSavedColors[te]; + // update viewer side color in anticipation of update from simulator + object->setTEColor(te, color); + } } + return true; } - } - - for ( object = mSelectedObjects->getFirstObject(); object; object = mSelectedObjects->getNextObject() ) - { - if (object->permModify()) - { - object->sendTEUpdate(); - } - } + } setfunc(mSelectedObjects); + getSelection()->applyToTEs(&setfunc); + + LLSelectMgrSendFunctor sendfunc; + getSelection()->applyToObjects(&sendfunc); } BOOL LLSelectMgr::selectionRevertTextures() { - LLViewerObject* object; - S32 te; - - BOOL revert_successful = TRUE; - for (mSelectedObjects->getFirstTE(&object, &te); object; mSelectedObjects->getNextTE(&object, &te) ) + struct f : public LLSelectedTEFunctor { - if (object->permModify()) + LLObjectSelectionHandle mSelectedObjects; + f(LLObjectSelectionHandle sel) : mSelectedObjects(sel) {} + bool apply(LLViewerObject* object, S32 te) { - LLSelectNode* nodep = mSelectedObjects->findNode(object); - if (nodep && te < (S32)nodep->mSavedTextures.size()) + if (object->permModify()) { - LLUUID id = nodep->mSavedTextures[te]; - // update textures on viewer side - if (id.isNull()) - { - // this was probably a no-copy texture, leave image as-is - revert_successful = FALSE; - } - else + LLSelectNode* nodep = mSelectedObjects->findNode(object); + if (nodep && te < (S32)nodep->mSavedTextures.size()) { - object->setTEImage(te, gImageList.getImage(id)); + LLUUID id = nodep->mSavedTextures[te]; + // update textures on viewer side + if (id.isNull()) + { + // this was probably a no-copy texture, leave image as-is + return FALSE; + } + else + { + object->setTEImage(te, gImageList.getImage(id)); + } } } + return true; } - } - - // propagate texture changes to server - for ( object = mSelectedObjects->getFirstObject(); object; object = mSelectedObjects->getNextObject() ) - { - if (object->permModify()) - { - object->sendTEUpdate(); - } - } + } setfunc(mSelectedObjects); + BOOL revert_successful = getSelection()->applyToTEs(&setfunc); + + LLSelectMgrSendFunctor sendfunc; + getSelection()->applyToObjects(&sendfunc); return revert_successful; } void LLSelectMgr::selectionSetBumpmap(U8 bumpmap) { - LLViewerObject* object; - S32 te; - for (mSelectedObjects->getFirstTE(&object, &te); object; mSelectedObjects->getNextTE(&object, &te) ) - { - if (object->permModify()) - { - // update viewer side color in anticipation of update from simulator - object->setTEBumpmap(te, bumpmap); - } - } - - for ( object = mSelectedObjects->getFirstObject(); object; object = mSelectedObjects->getNextObject() ) + struct f : public LLSelectedTEFunctor { - if (object->permModify()) + U8 mBump; + f(const U8& b) : mBump(b) {} + bool apply(LLViewerObject* object, S32 te) { - object->sendTEUpdate(); + if (object->permModify()) + { + // update viewer side color in anticipation of update from simulator + object->setTEBumpmap(te, mBump); + } + return true; } - } + } setfunc(bumpmap); + getSelection()->applyToTEs(&setfunc); + + LLSelectMgrSendFunctor sendfunc; + getSelection()->applyToObjects(&sendfunc); } void LLSelectMgr::selectionSetTexGen(U8 texgen) { - LLViewerObject* object; - S32 te; - for (mSelectedObjects->getFirstTE(&object, &te); object; mSelectedObjects->getNextTE(&object, &te) ) + struct f : public LLSelectedTEFunctor { - if (object->permModify()) + U8 mTexgen; + f(const U8& t) : mTexgen(t) {} + bool apply(LLViewerObject* object, S32 te) { - // update viewer side color in anticipation of update from simulator - object->setTETexGen(te, texgen); + if (object->permModify()) + { + // update viewer side color in anticipation of update from simulator + object->setTETexGen(te, mTexgen); + } + return true; } - } + } setfunc(texgen); + getSelection()->applyToTEs(&setfunc); - for ( object = mSelectedObjects->getFirstObject(); object; object = mSelectedObjects->getNextObject() ) - { - if (object->permModify()) - { - object->sendTEUpdate(); - } - } + LLSelectMgrSendFunctor sendfunc; + getSelection()->applyToObjects(&sendfunc); } void LLSelectMgr::selectionSetShiny(U8 shiny) { - LLViewerObject* object; - S32 te; - for (mSelectedObjects->getFirstTE(&object, &te); object; mSelectedObjects->getNextTE(&object, &te) ) + struct f : public LLSelectedTEFunctor { - if (object->permModify()) + U8 mShiny; + f(const U8& t) : mShiny(t) {} + bool apply(LLViewerObject* object, S32 te) { - // update viewer side color in anticipation of update from simulator - object->setTEShiny(te, shiny); + if (object->permModify()) + { + // update viewer side color in anticipation of update from simulator + object->setTEShiny(te, mShiny); + } + return true; } - } + } setfunc(shiny); + getSelection()->applyToTEs(&setfunc); - for ( object = mSelectedObjects->getFirstObject(); object; object = mSelectedObjects->getNextObject() ) - { - if (object->permModify()) - { - object->sendTEUpdate(); - } - } + LLSelectMgrSendFunctor sendfunc; + getSelection()->applyToObjects(&sendfunc); } void LLSelectMgr::selectionSetFullbright(U8 fullbright) { - LLViewerObject* object; - S32 te; - for (mSelectedObjects->getFirstTE(&object, &te); object; mSelectedObjects->getNextTE(&object, &te) ) + struct f : public LLSelectedTEFunctor { - if (object->permModify()) + U8 mFullbright; + f(const U8& t) : mFullbright(t) {} + bool apply(LLViewerObject* object, S32 te) { - // update viewer side color in anticipation of update from simulator - object->setTEFullbright(te, fullbright); + if (object->permModify()) + { + // update viewer side color in anticipation of update from simulator + object->setTEFullbright(te, mFullbright); + } + return true; } - } + } setfunc(fullbright); + getSelection()->applyToTEs(&setfunc); - for ( object = mSelectedObjects->getFirstObject(); object; object = mSelectedObjects->getNextObject() ) + struct g : public LLSelectedObjectFunctor { - if (object->permModify()) + U8 mFullbright; + g(const U8& t) : mFullbright(t) {} + virtual bool apply(LLViewerObject* object) { - object->sendTEUpdate(); - if (fullbright) + if (object->permModify()) { - U8 material = object->getMaterial(); - U8 mcode = material & LL_MCODE_MASK; - if (mcode == LL_MCODE_LIGHT) + object->sendTEUpdate(); + if (mFullbright) { - mcode = LL_MCODE_GLASS; - material = (material & ~LL_MCODE_MASK) | mcode; - object->setMaterial(material); - object->sendMaterialUpdate(); + U8 material = object->getMaterial(); + U8 mcode = material & LL_MCODE_MASK; + if (mcode == LL_MCODE_LIGHT) + { + mcode = LL_MCODE_GLASS; + material = (material & ~LL_MCODE_MASK) | mcode; + object->setMaterial(material); + object->sendMaterialUpdate(); + } } } + return true; } - } + } sendfunc(fullbright); + getSelection()->applyToObjects(&sendfunc); } void LLSelectMgr::selectionSetMediaTypeAndURL(U8 media_type, const std::string& media_url) { - LLViewerObject* object; - S32 te; U8 media_flags = LLTextureEntry::MF_NONE; if (media_type == LLViewerObject::MEDIA_TYPE_WEB_PAGE) { media_flags = LLTextureEntry::MF_WEB_PAGE; } - - for (mSelectedObjects->getFirstTE(&object, &te); object; mSelectedObjects->getNextTE(&object, &te) ) + + struct f : public LLSelectedTEFunctor { - if (object->permModify()) + U8 mMediaFlags; + f(const U8& t) : mMediaFlags(t) {} + bool apply(LLViewerObject* object, S32 te) { - // update viewer side color in anticipation of update from simulator - object->setTEMediaFlags(te, media_flags); + if (object->permModify()) + { + // update viewer side color in anticipation of update from simulator + object->setTEMediaFlags(te, mMediaFlags); + } + return true; } - } + } setfunc(media_flags); + getSelection()->applyToTEs(&setfunc); - for ( object = mSelectedObjects->getFirstObject(); object; object = mSelectedObjects->getNextObject() ) + struct g : public LLSelectedObjectFunctor { - if (object->permModify()) + U8 media_type; + const std::string& media_url ; + g(U8 a, const std::string& b) : media_type(a), media_url(b) {} + virtual bool apply(LLViewerObject* object) { - // JAMESDEBUG TODO set object media type - object->setMediaType(media_type); - object->setMediaURL(media_url); - - object->sendTEUpdate(); + if (object->permModify()) + { + object->sendTEUpdate(); + object->setMediaType(media_type); + object->setMediaURL(media_url); + } + return true; } - } + } sendfunc(media_type, media_url); + getSelection()->applyToObjects(&sendfunc); } @@ -1703,11 +1729,11 @@ void LLSelectMgr::selectionSetMediaTypeAndURL(U8 media_type, const std::string& //----------------------------------------------------------------------------- LLPermissions* LLSelectMgr::findObjectPermissions(const LLViewerObject* object) { - LLSelectNode* nodep; - - for (nodep = mSelectedObjects->getFirstNode(); nodep; nodep = mSelectedObjects->getNextNode() ) + for (LLObjectSelection::valid_iterator iter = getSelection()->valid_begin(); + iter != getSelection()->valid_end(); iter++ ) { - if((nodep->getObject() == object) && nodep->mValid) + LLSelectNode* nodep = *iter; + if (nodep->getObject() == object) { return nodep->mPermissions; } @@ -1718,339 +1744,138 @@ LLPermissions* LLSelectMgr::findObjectPermissions(const LLViewerObject* object) //----------------------------------------------------------------------------- -// selectionGetTexUUID() +// selectionSetMaterial() //----------------------------------------------------------------------------- -BOOL LLSelectMgr::selectionGetTexUUID(LLUUID& id) +void LLSelectMgr::selectionSetMaterial(U8 material) { - LLViewerObject* first_objectp; - S32 first_te; - mSelectedObjects->getPrimaryTE(&first_objectp, &first_te); - - // nothing selected - if (!first_objectp) - { - return FALSE; - } - - LLViewerImage* first_imagep = first_objectp->getTEImage(first_te); - - if (!first_imagep) - { - return FALSE; - } - - BOOL identical = TRUE; - LLViewerObject *objectp; - S32 te; - for (mSelectedObjects->getFirstTE(&objectp, &te); objectp; mSelectedObjects->getNextTE(&objectp, &te) ) + struct f : public LLSelectedObjectFunctor { - if (objectp->getTEImage(te) != first_imagep) + U8 mMaterial; + f(const U8& t) : mMaterial(t) {} + virtual bool apply(LLViewerObject* object) { - identical = FALSE; - break; - } - } - - id = first_imagep->getID(); - return identical; -} - -//----------------------------------------------------------------------------- -// selectionGetColor() -//----------------------------------------------------------------------------- -BOOL LLSelectMgr::selectionGetColor(LLColor4 &color) -{ - LLViewerObject* first_object; - S32 first_te; - mSelectedObjects->getPrimaryTE(&first_object, &first_te); - - // nothing selected - if (!first_object) - { - return FALSE; - } - - LLColor4 first_color; - if (!first_object->getTE(first_te)) - { - return FALSE; - } - else - { - first_color = first_object->getTE(first_te)->getColor(); - } - - BOOL identical = TRUE; - LLViewerObject* object; - S32 te; - for (mSelectedObjects->getFirstTE(&object, &te); object; mSelectedObjects->getNextTE(&object, &te)) - { - if (!object->getTE(te) || (object->getTE(te)->getColor() != first_color)) - { - identical = FALSE; - break; + if (object->permModify()) + { + U8 cur_material = object->getMaterial(); + U8 material = mMaterial | (cur_material & ~LL_MCODE_MASK); + object->setMaterial(material); + object->sendMaterialUpdate(); + } + return true; } - } - - color = first_color; - return identical; + } sendfunc(material); + getSelection()->applyToObjects(&sendfunc); } - -//----------------------------------------------------------------------------- -// selectionGetBumpmap() -//----------------------------------------------------------------------------- -BOOL LLSelectMgr::selectionGetBumpmap(U8 *bumpmap) +// TRUE if all selected objects have this PCode +BOOL LLSelectMgr::selectionAllPCode(LLPCode code) { - LLViewerObject* first_object; - S32 first_te; - mSelectedObjects->getPrimaryTE(&first_object, &first_te); - - // nothing selected - if (!first_object) + struct f : public LLSelectedObjectFunctor { - return FALSE; - } - - U8 first_value; - if (!first_object->getTE(first_te)) - { - return FALSE; - } - else - { - first_value = first_object->getTE(first_te)->getBumpmap(); - } - - BOOL identical = TRUE; - LLViewerObject* object; - S32 te; - for (mSelectedObjects->getFirstTE(&object, &te); object; mSelectedObjects->getNextTE(&object, &te)) - { - if (!object->getTE(te) || (object->getTE(te)->getBumpmap() != first_value)) + LLPCode mCode; + f(const LLPCode& t) : mCode(t) {} + virtual bool apply(LLViewerObject* object) { - identical = FALSE; - break; + if (object->getPCode() != mCode) + { + return FALSE; + } + return true; } - } - - *bumpmap = first_value; - return identical; + } func(code); + BOOL res = getSelection()->applyToObjects(&func); + return res; } -//----------------------------------------------------------------------------- -// selectionGetShiny() -//----------------------------------------------------------------------------- -BOOL LLSelectMgr::selectionGetShiny(U8 *shiny) +bool LLSelectMgr::selectionGetIncludeInSearch(bool* include_in_search_out) { - LLViewerObject* first_object; - S32 first_te; - mSelectedObjects->getPrimaryTE(&first_object, &first_te); - - // nothing selected - if (!first_object) - { - return FALSE; - } - - U8 first_value; - if (!first_object->getTE(first_te)) - { - return FALSE; - } - else - { - first_value = first_object->getTE(first_te)->getShiny(); - } - - BOOL identical = TRUE; - LLViewerObject* object; - S32 te; - for (mSelectedObjects->getFirstTE(&object, &te); object; mSelectedObjects->getNextTE(&object, &te)) - { - if (!object->getTE(te) || (object->getTE(te)->getShiny() != first_value)) - { - identical = FALSE; - break; - } - } - - *shiny = first_value; - return identical; -} + LLViewerObject *object = mSelectedObjects->getFirstRootObject(); + if (!object) return FALSE; -//----------------------------------------------------------------------------- -// selectionGetFullbright() -//----------------------------------------------------------------------------- -BOOL LLSelectMgr::selectionGetFullbright(U8 *fullbright) -{ - LLViewerObject* first_object; - S32 first_te; - mSelectedObjects->getPrimaryTE(&first_object, &first_te); + bool include_in_search = object->getIncludeInSearch(); - // nothing selected - if (!first_object) - { - return FALSE; - } + bool identical = true; - U8 first_value; - if (!first_object->getTE(first_te)) - { - return FALSE; - } - else + for (LLObjectSelection::root_iterator iter = getSelection()->root_begin(); + iter != getSelection()->root_end(); iter++) { - first_value = first_object->getTE(first_te)->getFullbright(); - } + LLViewerObject* object = (*iter)->getObject(); - BOOL identical = TRUE; - LLViewerObject* object; - S32 te; - for (mSelectedObjects->getFirstTE(&object, &te); object; mSelectedObjects->getNextTE(&object, &te)) - { - if (!object->getTE(te) || (object->getTE(te)->getFullbright() != first_value)) - { - identical = FALSE; - break; - } - } - - *fullbright = first_value; - return identical; -} - -// JAMESDEBUG TODO make this return mediatype off viewer object -bool LLSelectMgr::selectionGetMediaType(U8 *media_type) -{ - LLViewerObject* first_object; - S32 first_te; - mSelectedObjects->getPrimaryTE(&first_object, &first_te); - - // nothing selected - if (!first_object) - { - return false; - } - - U8 first_value; - if (!first_object->getTE(first_te)) - { - return false; - } - else - { - first_value = first_object->getTE(first_te)->getMediaFlags(); - } - - bool identical = true; - LLViewerObject* object; - S32 te; - for (mSelectedObjects->getFirstTE(&object, &te); object; mSelectedObjects->getNextTE(&object, &te)) - { - if (!object->getTE(te) || (object->getTE(te)->getMediaFlags() != first_value)) + if ( include_in_search != object->getIncludeInSearch()) { identical = false; break; } } - *media_type = first_value; + *include_in_search_out = include_in_search; return identical; } - - -//----------------------------------------------------------------------------- -// selectionSetMaterial() -//----------------------------------------------------------------------------- -void LLSelectMgr::selectionSetMaterial(U8 material) -{ - LLViewerObject* object; - for (object = mSelectedObjects->getFirstObject(); object != NULL; object = mSelectedObjects->getNextObject() ) - { - if (object->permModify()) - { - U8 cur_material = object->getMaterial(); - material |= (cur_material & ~LL_MCODE_MASK); - object->setMaterial(material); - object->sendMaterialUpdate(); - } - } -} - -// True if all selected objects have this PCode -BOOL LLSelectMgr::selectionAllPCode(LLPCode code) +void LLSelectMgr::selectionSetIncludeInSearch(bool include_in_search) { - LLViewerObject *object; - for ( object = mSelectedObjects->getFirstObject(); object; object = mSelectedObjects->getNextObject() ) + LLViewerObject* object = NULL; + for (LLObjectSelection::root_iterator iter = getSelection()->root_begin(); + iter != getSelection()->root_end(); iter++) { - if (object->getPCode() != code) - { - return FALSE; - } + object = (*iter)->getObject(); + object->setIncludeInSearch(include_in_search); } - return TRUE; + sendListToRegions( + "ObjectIncludeInSearch", + packAgentAndSessionID, + packObjectIncludeInSearch, + &include_in_search, + SEND_ONLY_ROOTS); } -//----------------------------------------------------------------------------- -// selectionGetMaterial() -//----------------------------------------------------------------------------- -BOOL LLSelectMgr::selectionGetMaterial(U8 *out_material) +BOOL LLSelectMgr::selectionGetClickAction(U8 *out_action) { LLViewerObject *object = mSelectedObjects->getFirstObject(); - if (!object) return FALSE; - - U8 material = object->getMaterial(); - - BOOL identical = TRUE; - for ( object = mSelectedObjects->getFirstObject(); object; object = mSelectedObjects->getNextObject() ) + if (!object) { - if ( material != object->getMaterial()) - { - identical = FALSE; - break; - } + return FALSE; } - - *out_material = material; - return identical; -} - -BOOL LLSelectMgr::selectionGetClickAction(U8 *out_action) -{ - LLViewerObject *object = mSelectedObjects->getFirstObject(); - if (!object) return FALSE; - + U8 action = object->getClickAction(); + *out_action = action; - BOOL identical = TRUE; - for ( object = mSelectedObjects->getFirstObject(); object; object = mSelectedObjects->getNextObject() ) + struct f : public LLSelectedObjectFunctor { - if ( action != object->getClickAction()) + U8 mAction; + f(const U8& t) : mAction(t) {} + virtual bool apply(LLViewerObject* object) { - identical = FALSE; - break; + if ( mAction != object->getClickAction()) + { + return false; + } + return true; } - } - - *out_action = action; - return identical; + } func(action); + BOOL res = getSelection()->applyToObjects(&func); + return res; } void LLSelectMgr::selectionSetClickAction(U8 action) { - LLViewerObject* object = NULL; - for ( object = mSelectedObjects->getFirstObject(); object; object = mSelectedObjects->getNextObject() ) + struct f : public LLSelectedObjectFunctor { - object->setClickAction(action); - } - sendListToRegions( - "ObjectClickAction", - packAgentAndSessionID, - packObjectClickAction, - &action, - SEND_INDIVIDUALS); + U8 mAction; + f(const U8& t) : mAction(t) {} + virtual bool apply(LLViewerObject* object) + { + object->setClickAction(mAction); + return true; + } + } func(action); + getSelection()->applyToObjects(&func); + + sendListToRegions("ObjectClickAction", + packAgentAndSessionID, + packObjectClickAction, + &action, + SEND_INDIVIDUALS); } @@ -2125,34 +1950,42 @@ void LLSelectMgr::packObjectIDAsParam(LLSelectNode* node, void *) //----------------------------------------------------------------------------- void LLSelectMgr::selectionResetRotation() { - LLQuaternion identity(0.f, 0.f, 0.f, 1.f); - - LLViewerObject* object; - for (object = mSelectedObjects->getFirstRootObject(); object; object = mSelectedObjects->getNextRootObject() ) + struct f : public LLSelectedObjectFunctor { - object->setRotation(identity); - if (object->mDrawable.notNull()) + virtual bool apply(LLViewerObject* object) { - gPipeline.markMoved(object->mDrawable, TRUE); + LLQuaternion identity(0.f, 0.f, 0.f, 1.f); + object->setRotation(identity); + if (object->mDrawable.notNull()) + { + gPipeline.markMoved(object->mDrawable, TRUE); + } + object->sendRotationUpdate(); + return true; } - object->sendRotationUpdate(); - } + } func; + getSelection()->applyToRootObjects(&func); } void LLSelectMgr::selectionRotateAroundZ(F32 degrees) { LLQuaternion rot( degrees * DEG_TO_RAD, LLVector3(0,0,1) ); - - LLViewerObject* object; - for (object = mSelectedObjects->getFirstRootObject(); object; object = mSelectedObjects->getNextRootObject() ) + struct f : public LLSelectedObjectFunctor { - object->setRotation( object->getRotationEdit() * rot ); - if (object->mDrawable.notNull()) + LLQuaternion mRot; + f(const LLQuaternion& rot) : mRot(rot) {} + virtual bool apply(LLViewerObject* object) { - gPipeline.markMoved(object->mDrawable, TRUE); + object->setRotation( object->getRotationEdit() * mRot ); + if (object->mDrawable.notNull()) + { + gPipeline.markMoved(object->mDrawable, TRUE); + } + object->sendRotationUpdate(); + return true; } - object->sendRotationUpdate(); - } + } func(rot); + getSelection()->applyToRootObjects(&func); } @@ -2161,86 +1994,37 @@ void LLSelectMgr::selectionRotateAroundZ(F32 degrees) //----------------------------------------------------------------------------- void LLSelectMgr::selectionTexScaleAutofit(F32 repeats_per_meter) { - LLViewerObject* object; - S32 te; - for (mSelectedObjects->getFirstTE(&object, &te); object; mSelectedObjects->getNextTE(&object, &te)) + struct f : public LLSelectedTEFunctor { - if (!object->permModify()) + F32 mRepeatsPerMeter; + f(const F32& t) : mRepeatsPerMeter(t) {} + bool apply(LLViewerObject* object, S32 te) { - continue; - } + + if (object->permModify()) + { + // Compute S,T to axis mapping + U32 s_axis, t_axis; + if (!LLPrimitive::getTESTAxes(te, &s_axis, &t_axis)) + { + return TRUE; + } - if (object->getNumTEs() == 0) - { - continue; - } + F32 new_s = object->getScale().mV[s_axis] * mRepeatsPerMeter; + F32 new_t = object->getScale().mV[t_axis] * mRepeatsPerMeter; - // Compute S,T to axis mapping - U32 s_axis, t_axis; - if (!getTESTAxes(object, te, &s_axis, &t_axis)) - { - continue; + object->setTEScale(te, new_s, new_t); + } + return true; } + } setfunc(repeats_per_meter); + getSelection()->applyToTEs(&setfunc); - F32 new_s = object->getScale().mV[s_axis] * repeats_per_meter; - F32 new_t = object->getScale().mV[t_axis] * repeats_per_meter; - - object->setTEScale(te, new_s, new_t); - } - - for (object = mSelectedObjects->getFirstObject(); object; object = mSelectedObjects->getNextObject()) - { - if (object->permModify()) - { - object->sendTEUpdate(); - } - } + LLSelectMgrSendFunctor sendfunc; + getSelection()->applyToObjects(&sendfunc); } -// BUG: Only works for boxes. -// Face numbering for flex boxes as of 1.14.2002 -//----------------------------------------------------------------------------- -// getFaceSTAxes() -//----------------------------------------------------------------------------- -BOOL LLSelectMgr::getTESTAxes(const LLViewerObject* object, const U8 face, U32* s_axis, U32* t_axis) -{ - if (face == 0) - { - *s_axis = VX; *t_axis = VY; - return TRUE; - } - else if (face == 1) - { - *s_axis = VX; *t_axis = VZ; - return TRUE; - } - else if (face == 2) - { - *s_axis = VY; *t_axis = VZ; - return TRUE; - } - else if (face == 3) - { - *s_axis = VX; *t_axis = VZ; - return TRUE; - } - else if (face == 4) - { - *s_axis = VY; *t_axis = VZ; - return TRUE; - } - else if (face == 5) - { - *s_axis = VX; *t_axis = VY; - return TRUE; - } - else - { - // unknown face - return FALSE; - } -} // Called at the end of a scale operation, this adjusts the textures to attempt to // maintain a constant repeats per meter. @@ -2250,14 +2034,12 @@ BOOL LLSelectMgr::getTESTAxes(const LLViewerObject* object, const U8 face, U32* //----------------------------------------------------------------------------- void LLSelectMgr::adjustTexturesByScale(BOOL send_to_sim, BOOL stretch) { - LLViewerObject* object; - LLSelectNode* selectNode; - - BOOL send = FALSE; - - for (selectNode = mSelectedObjects->getFirstNode(); selectNode; selectNode = mSelectedObjects->getNextNode()) + for (LLObjectSelection::iterator iter = getSelection()->begin(); + iter != getSelection()->end(); iter++) { - object = selectNode->getObject(); + LLSelectNode* selectNode = *iter; + LLViewerObject* object = selectNode->getObject(); + if (!object->permModify()) { continue; @@ -2268,6 +2050,8 @@ void LLSelectMgr::adjustTexturesByScale(BOOL send_to_sim, BOOL stretch) continue; } + BOOL send = FALSE; + for (U8 te_num = 0; te_num < object->getNumTEs(); te_num++) { const LLTextureEntry* tep = object->getTE(te_num); @@ -2277,8 +2061,11 @@ void LLSelectMgr::adjustTexturesByScale(BOOL send_to_sim, BOOL stretch) { // Figure out how S,T changed with scale operation U32 s_axis, t_axis; - if (!getTESTAxes(object, te_num, &s_axis, &t_axis)) continue; - + if (!LLPrimitive::getTESTAxes(te_num, &s_axis, &t_axis)) + { + continue; + } + LLVector3 scale_ratio = selectNode->mTextureScaleRatios[te_num]; LLVector3 object_scale = object->getScale(); @@ -2301,70 +2088,23 @@ void LLSelectMgr::adjustTexturesByScale(BOOL send_to_sim, BOOL stretch) { object->sendTEUpdate(); } - } -} - - -//----------------------------------------------------------------------------- -// selectionResetTexInfo() -//----------------------------------------------------------------------------- -void LLSelectMgr::selectionResetTexInfo(S32 selected_face) -{ - S32 start_face, end_face; - - LLViewerObject* object; - for (object = mSelectedObjects->getFirstObject(); object; object = mSelectedObjects->getNextObject()) - { - if (!object->permModify()) - { - continue; - } - if (object->getNumTEs() == 0) - { - continue; - } - - if (selected_face == -1) - { - start_face = 0; - end_face = object->getNumTEs() - 1; - } - else - { - start_face = selected_face; - end_face = selected_face; - } - - for (S32 face = start_face; face <= end_face; face++) - { - // Actually, each object should reset to its appropriate value. - object->setTEScale(face, 1.f, 1.f); - object->setTEOffset(face, 0.f, 0.f); - object->setTERotation(face, 0.f); - } - - object->sendTEUpdate(); - } + } } //----------------------------------------------------------------------------- // selectGetAllRootsValid() -// Returns true if the viewer has information on all selected objects +// Returns TRUE if the viewer has information on all selected objects //----------------------------------------------------------------------------- BOOL LLSelectMgr::selectGetAllRootsValid() { - for( LLSelectNode* node = mSelectedObjects->getFirstRootNode(); node; node = mSelectedObjects->getNextRootNode() ) + for (LLObjectSelection::root_iterator iter = getSelection()->root_begin(); + iter != getSelection()->root_end(); ++iter ) { - + LLSelectNode* node = *iter; if( !node->mValid ) { return FALSE; } - - if( !node->getObject() ) - { - return FALSE; - } } return TRUE; } @@ -2372,63 +2112,62 @@ BOOL LLSelectMgr::selectGetAllRootsValid() //----------------------------------------------------------------------------- // selectGetAllValid() -// Returns true if the viewer has information on all selected objects +// Returns TRUE if the viewer has information on all selected objects //----------------------------------------------------------------------------- BOOL LLSelectMgr::selectGetAllValid() { - for( LLSelectNode* node = mSelectedObjects->getFirstNode(); node; node = mSelectedObjects->getNextNode() ) + for (LLObjectSelection::iterator iter = getSelection()->begin(); + iter != getSelection()->end(); ++iter ) { - + LLSelectNode* node = *iter; if( !node->mValid ) { return FALSE; } - - if( !node->getObject() ) - { - return FALSE; - } } return TRUE; } //----------------------------------------------------------------------------- -// selectGetModify() - return true if current agent can modify all +// selectGetModify() - return TRUE if current agent can modify all // selected objects. //----------------------------------------------------------------------------- BOOL LLSelectMgr::selectGetModify() { - for( LLSelectNode* node = mSelectedObjects->getFirstNode(); node; node = mSelectedObjects->getNextNode() ) + for (LLObjectSelection::iterator iter = getSelection()->begin(); + iter != getSelection()->end(); iter++ ) { + LLSelectNode* node = *iter; + LLViewerObject* object = node->getObject(); if( !node->mValid ) { return FALSE; } - LLViewerObject* object = node->getObject(); - if( !object || !object->permModify() ) + if( !object->permModify() ) { return FALSE; } } - return TRUE; } //----------------------------------------------------------------------------- -// selectGetRootsModify() - return true if current agent can modify all +// selectGetRootsModify() - return TRUE if current agent can modify all // selected root objects. //----------------------------------------------------------------------------- BOOL LLSelectMgr::selectGetRootsModify() { - for( LLSelectNode* node = mSelectedObjects->getFirstRootNode(); node; node = mSelectedObjects->getNextRootNode() ) + for (LLObjectSelection::root_iterator iter = getSelection()->root_begin(); + iter != getSelection()->root_end(); iter++ ) { + LLSelectNode* node = *iter; + LLViewerObject* object = node->getObject(); if( !node->mValid ) { return FALSE; } - LLViewerObject* object = node->getObject(); - if( !object || !object->permModify() ) + if( !object->permModify() ) { return FALSE; } @@ -2439,19 +2178,21 @@ BOOL LLSelectMgr::selectGetRootsModify() //----------------------------------------------------------------------------- -// selectGetRootsTransfer() - return true if current agent can transfer all +// selectGetRootsTransfer() - return TRUE if current agent can transfer all // selected root objects. //----------------------------------------------------------------------------- BOOL LLSelectMgr::selectGetRootsTransfer() { - for(LLSelectNode* node = mSelectedObjects->getFirstRootNode(); node; node = mSelectedObjects->getNextRootNode()) + for (LLObjectSelection::root_iterator iter = getSelection()->root_begin(); + iter != getSelection()->root_end(); iter++ ) { - if(!node->mValid) + LLSelectNode* node = *iter; + LLViewerObject* object = node->getObject(); + if( !node->mValid ) { return FALSE; } - LLViewerObject* object = node->getObject(); - if(!object || !object->permTransfer()) + if(!object->permTransfer()) { return FALSE; } @@ -2460,19 +2201,21 @@ BOOL LLSelectMgr::selectGetRootsTransfer() } //----------------------------------------------------------------------------- -// selectGetRootsCopy() - return true if current agent can copy all +// selectGetRootsCopy() - return TRUE if current agent can copy all // selected root objects. //----------------------------------------------------------------------------- BOOL LLSelectMgr::selectGetRootsCopy() { - for(LLSelectNode* node = mSelectedObjects->getFirstRootNode(); node; node = mSelectedObjects->getNextRootNode()) + for (LLObjectSelection::root_iterator iter = getSelection()->root_begin(); + iter != getSelection()->root_end(); iter++ ) { - if(!node->mValid) + LLSelectNode* node = *iter; + LLViewerObject* object = node->getObject(); + if( !node->mValid ) { return FALSE; } - LLViewerObject* object = node->getObject(); - if(!object || !object->permCopy()) + if(!object->permCopy()) { return FALSE; } @@ -2484,39 +2227,42 @@ BOOL LLSelectMgr::selectGetRootsCopy() // selectGetCreator() // Creator information only applies to root objects. //----------------------------------------------------------------------------- -BOOL LLSelectMgr::selectGetCreator(LLUUID& id, LLString& name) +BOOL LLSelectMgr::selectGetCreator(LLUUID& result_id, LLString& name) { - LLSelectNode* node = mSelectedObjects->getFirstRootNode(); - if(!node) node = mSelectedObjects->getFirstNode(); - if(!node) return FALSE; - if(!node->mValid) return FALSE; - LLViewerObject* obj = node->getObject(); - if(!obj) return FALSE; - if(!(obj->isRoot() || obj->isJointChild())) return FALSE; - - id = node->mPermissions->getCreator(); - BOOL identical = TRUE; - for ( node = mSelectedObjects->getNextRootNode(); node; node = mSelectedObjects->getNextRootNode() ) + BOOL first = TRUE; + LLUUID first_id; + for (LLObjectSelection::root_iterator iter = getSelection()->root_begin(); + iter != getSelection()->root_end(); iter++ ) { + LLSelectNode* node = *iter; if (!node->mValid) { - identical = FALSE; - break; + return FALSE; } - if ( !(id == node->mPermissions->getCreator() ) ) + if (first) { - identical = FALSE; - break; + first_id = node->mPermissions->getCreator(); + first = FALSE; + } + else + { + if ( !(first_id == node->mPermissions->getCreator() ) ) + { + identical = FALSE; + break; + } } } + result_id = first_id; + if (identical) { char firstname[DB_FIRST_NAME_BUF_SIZE]; /* Flawfinder: ignore */ char lastname[DB_LAST_NAME_BUF_SIZE]; /* Flawfinder: ignore */ - gCacheName->getName(id, firstname, lastname); + gCacheName->getName(first_id, firstname, lastname); name.assign( firstname ); name.append( " " ); name.append( lastname ); @@ -2534,44 +2280,45 @@ BOOL LLSelectMgr::selectGetCreator(LLUUID& id, LLString& name) // selectGetOwner() // Owner information only applies to roots. //----------------------------------------------------------------------------- -BOOL LLSelectMgr::selectGetOwner(LLUUID& id, LLString& name) +BOOL LLSelectMgr::selectGetOwner(LLUUID& result_id, LLString& name) { - LLSelectNode* node = mSelectedObjects->getFirstRootNode(); - if(!node) node = mSelectedObjects->getFirstNode(); - if(!node) return FALSE; - if(!node->mValid) return FALSE; - LLViewerObject* obj = node->getObject(); - if(!obj) return FALSE; - if(!(obj->isRootEdit() || obj->isRoot() || obj->isJointChild())) return FALSE; - - BOOL group_owner = FALSE; - id.setNull(); - node->mPermissions->getOwnership(id, group_owner); - BOOL identical = TRUE; - for ( node = mSelectedObjects->getNextRootNode(); node; node = mSelectedObjects->getNextRootNode() ) + BOOL first = TRUE; + BOOL first_group_owned = FALSE; + LLUUID first_id; + for (LLObjectSelection::root_iterator iter = getSelection()->root_begin(); + iter != getSelection()->root_end(); iter++ ) { + LLSelectNode* node = *iter; if (!node->mValid) { - identical = FALSE; - break; + return FALSE; } - - LLUUID owner_id; - BOOL is_group_owned = FALSE; - if (!(node->mPermissions->getOwnership(owner_id, is_group_owned)) - || owner_id != id ) + + if (first) { - identical = FALSE; - break; + node->mPermissions->getOwnership(first_id, first_group_owned); + first = FALSE; + } + else + { + LLUUID owner_id; + BOOL is_group_owned = FALSE; + if (!(node->mPermissions->getOwnership(owner_id, is_group_owned)) + || owner_id != first_id || is_group_owned != first_group_owned) + { + identical = FALSE; + break; + } } } - BOOL public_owner = (id.isNull() && !group_owner); - + result_id = first_id; + if (identical) { - if (group_owner) + BOOL public_owner = (first_id.isNull() && !first_group_owned); + if (first_group_owned) { name.assign( "(Group Owned)"); } @@ -2579,7 +2326,7 @@ BOOL LLSelectMgr::selectGetOwner(LLUUID& id, LLString& name) { char firstname[DB_FIRST_NAME_BUF_SIZE]; /* Flawfinder: ignore */ char lastname[DB_LAST_NAME_BUF_SIZE]; /* Flawfinder: ignore */ - gCacheName->getName(id, firstname, lastname); + gCacheName->getName(first_id, firstname, lastname); name.assign( firstname ); name.append( " " ); name.append( lastname ); @@ -2602,43 +2349,45 @@ BOOL LLSelectMgr::selectGetOwner(LLUUID& id, LLString& name) // selectGetLastOwner() // Owner information only applies to roots. //----------------------------------------------------------------------------- -BOOL LLSelectMgr::selectGetLastOwner(LLUUID& id, LLString& name) +BOOL LLSelectMgr::selectGetLastOwner(LLUUID& result_id, LLString& name) { - LLSelectNode* node = mSelectedObjects->getFirstRootNode(); - if(!node) node = mSelectedObjects->getFirstNode(); - if(!node) return FALSE; - if(!node->mValid) return FALSE; - LLViewerObject* obj = node->getObject(); - if(!obj) return FALSE; - if(!(obj->isRoot() || obj->isJointChild())) return FALSE; - - id = node->mPermissions->getLastOwner(); - BOOL identical = TRUE; - for ( node = mSelectedObjects->getNextRootNode(); node; node = mSelectedObjects->getNextRootNode() ) + BOOL first = TRUE; + LLUUID first_id; + for (LLObjectSelection::root_iterator iter = getSelection()->root_begin(); + iter != getSelection()->root_end(); iter++ ) { + LLSelectNode* node = *iter; if (!node->mValid) { - identical = FALSE; - break; + return FALSE; } - if ( !(id == node->mPermissions->getLastOwner() ) ) + if (first) { - identical = FALSE; - break; + first_id = node->mPermissions->getLastOwner(); + first = FALSE; + } + else + { + if ( !(first_id == node->mPermissions->getLastOwner() ) ) + { + identical = FALSE; + break; + } } } - BOOL public_owner = (id.isNull()); - + result_id = first_id; + if (identical) { + BOOL public_owner = (first_id.isNull()); if(!public_owner) { char firstname[DB_FIRST_NAME_BUF_SIZE]; /* Flawfinder: ignore */ char lastname[DB_LAST_NAME_BUF_SIZE]; /* Flawfinder: ignore */ - gCacheName->getName(id, firstname, lastname); + gCacheName->getName(first_id, firstname, lastname); name.assign( firstname ); name.append( " " ); name.append( lastname ); @@ -2661,33 +2410,36 @@ BOOL LLSelectMgr::selectGetLastOwner(LLUUID& id, LLString& name) // selectGetGroup() // Group information only applies to roots. //----------------------------------------------------------------------------- -BOOL LLSelectMgr::selectGetGroup(LLUUID& id) +BOOL LLSelectMgr::selectGetGroup(LLUUID& result_id) { - LLSelectNode* node = mSelectedObjects->getFirstRootNode(); - if(!node) node = mSelectedObjects->getFirstNode(); - if(!node) return FALSE; - if(!node->mValid) return FALSE; - LLViewerObject* obj = node->getObject(); - if(!obj) return FALSE; - if(!(obj->isRoot() || obj->isJointChild())) return FALSE; - - id = node->mPermissions->getGroup(); - BOOL identical = TRUE; - for ( node = mSelectedObjects->getNextRootNode(); node; node = mSelectedObjects->getNextRootNode() ) + BOOL first = TRUE; + LLUUID first_id; + for (LLObjectSelection::root_iterator iter = getSelection()->root_begin(); + iter != getSelection()->root_end(); iter++ ) { + LLSelectNode* node = *iter; if (!node->mValid) { - identical = FALSE; - break; + return FALSE; } - if ( !(id == node->mPermissions->getGroup() ) ) + if (first) { - identical = FALSE; - break; + first_id = node->mPermissions->getGroup(); + first = FALSE; + } + else + { + if ( !(first_id == node->mPermissions->getGroup() ) ) + { + identical = FALSE; + break; + } } } + + result_id = first_id; return identical; } @@ -2699,64 +2451,53 @@ BOOL LLSelectMgr::selectGetGroup(LLUUID& id) //----------------------------------------------------------------------------- BOOL LLSelectMgr::selectIsGroupOwned() { - LLSelectNode* node = mSelectedObjects->getFirstRootNode(); - if(!node) node = mSelectedObjects->getFirstNode(); - if(!node) return FALSE; - if(!node->mValid) return FALSE; - LLViewerObject* obj = node->getObject(); - if(!obj) return FALSE; - if(!(obj->isRoot() || obj->isJointChild())) return FALSE; - - BOOL is_group_owned = node->mPermissions->isGroupOwned(); - - if(is_group_owned) + BOOL found_one = FALSE; + for (LLObjectSelection::root_iterator iter = getSelection()->root_begin(); + iter != getSelection()->root_end(); iter++ ) { - for ( node = mSelectedObjects->getNextRootNode(); node; node = mSelectedObjects->getNextRootNode() ) + LLSelectNode* node = *iter; + if (!node->mValid) { - if (!node->mValid) - { - is_group_owned = FALSE; - break; - } - - if ( !( node->mPermissions->isGroupOwned() ) ) - { - is_group_owned = FALSE; - break; - } + return FALSE; } - } - return is_group_owned; + found_one = TRUE; + if (!node->mPermissions->isGroupOwned()) + { + return FALSE; + } + } + return found_one ? TRUE : FALSE; } //----------------------------------------------------------------------------- // selectGetPerm() // Only operates on root nodes. // Returns TRUE if all have valid data. -// mask_on has bits set to true where all permissions are true -// mask_off has bits set to true where all permissions are false +// mask_on has bits set to TRUE where all permissions are TRUE +// mask_off has bits set to TRUE where all permissions are FALSE // if a bit is off both in mask_on and mask_off, the values differ within // the selection. //----------------------------------------------------------------------------- BOOL LLSelectMgr::selectGetPerm(U8 which_perm, U32* mask_on, U32* mask_off) { - LLSelectNode* node = mSelectedObjects->getFirstRootNode(); - if (!node) return FALSE; - if (!node->mValid) return FALSE; - U32 mask; U32 mask_and = 0xffffffff; U32 mask_or = 0x00000000; - BOOL all_valid = TRUE; + BOOL all_valid = FALSE; - for ( node = mSelectedObjects->getFirstRootNode(); node; node = mSelectedObjects->getNextRootNode() ) + for (LLObjectSelection::root_iterator iter = getSelection()->root_begin(); + iter != getSelection()->root_end(); iter++) { + LLSelectNode* node = *iter; + if (!node->mValid) { all_valid = FALSE; break; } + all_valid = TRUE; + switch( which_perm ) { case PERM_BASE: @@ -2784,10 +2525,10 @@ BOOL LLSelectMgr::selectGetPerm(U8 which_perm, U32* mask_on, U32* mask_off) if (all_valid) { - // ...true through all ANDs means all true + // ...TRUE through all ANDs means all TRUE *mask_on = mask_and; - // ...false through all ORs means all false + // ...FALSE through all ORs means all FALSE *mask_off = ~mask_or; return TRUE; } @@ -2806,23 +2547,33 @@ BOOL LLSelectMgr::selectGetOwnershipCost(S32* out_cost) return mSelectedObjects->getOwnershipCost(*out_cost); } -BOOL LLSelectMgr::selectGetPermissions(LLPermissions& perm) +BOOL LLSelectMgr::selectGetPermissions(LLPermissions& result_perm) { - LLSelectNode* node = mSelectedObjects->getFirstRootNode(); - if (!node) return FALSE; - if (!node->mValid) return FALSE; - BOOL valid = TRUE; - perm = *(node->mPermissions); - for(node = mSelectedObjects->getNextRootNode(); node != NULL; node = mSelectedObjects->getNextRootNode()) + BOOL first = TRUE; + LLPermissions perm; + for (LLObjectSelection::root_iterator iter = getSelection()->root_begin(); + iter != getSelection()->root_end(); iter++ ) { - if(!node->mValid) + LLSelectNode* node = *iter; + if (!node->mValid) { - valid = FALSE; - break; + return FALSE; + } + + if (first) + { + perm = *(node->mPermissions); + first = FALSE; + } + else + { + perm.accumulate(*(node->mPermissions)); } - perm.accumulate(*(node->mPermissions)); } - return valid; + + result_perm = perm; + + return TRUE; } @@ -2833,10 +2584,12 @@ void LLSelectMgr::selectDelete() BOOL locked_but_deleteable_object = FALSE; BOOL no_copy_but_deleteable_object = FALSE; BOOL all_owned_by_you = TRUE; - for(LLViewerObject* obj = mSelectedObjects->getFirstObject(); - obj != NULL; - obj = mSelectedObjects->getNextObject()) + + for (LLObjectSelection::iterator iter = getSelection()->begin(); + iter != getSelection()->end(); iter++) { + LLViewerObject* obj = (*iter)->getObject(); + if( obj->isAttachment() ) { continue; @@ -2958,10 +2711,10 @@ void LLSelectMgr::confirmDelete(S32 option, void* data) // attempt to derez into the trash. LLDeRezInfo* info = new LLDeRezInfo(DRD_TRASH, trash_id); gSelectMgr->sendListToRegions("DeRezObject", - packDeRezHeader, - packObjectLocalID, - (void*)info, - SEND_ONLY_ROOTS); + packDeRezHeader, + packObjectLocalID, + (void*)info, + SEND_ONLY_ROOTS); // VEFFECT: Delete Object - one effect for all deletes if (gSelectMgr->mSelectedObjects->mSelectType != SELECT_TYPE_HUD) { @@ -3006,9 +2759,10 @@ BOOL LLSelectMgr::selectIsForSale(S32& price) BOOL any_for_sale = FALSE; price = 0; - LLSelectNode *node; - for (node = mSelectedObjects->getFirstRootNode(); node; node = mSelectedObjects->getNextRootNode() ) + for (LLObjectSelection::root_iterator iter = getSelection()->root_begin(); + iter != getSelection()->root_end(); iter++) { + LLSelectNode* node = *iter; if (node->mSaleInfo.isForSale()) { price += node->mSaleInfo.getSalePrice(); @@ -3022,61 +2776,92 @@ BOOL LLSelectMgr::selectIsForSale(S32& price) // returns TRUE if all nodes are valid. method also stores an // accumulated sale info. -BOOL LLSelectMgr::selectGetSaleInfo(LLSaleInfo& sale_info) +BOOL LLSelectMgr::selectGetSaleInfo(LLSaleInfo& result_sale_info) { - LLSelectNode* node = mSelectedObjects->getFirstRootNode(); - if (!node) return FALSE; - if (!node->mValid) return FALSE; - BOOL valid = TRUE; - sale_info = node->mSaleInfo; - for(node = mSelectedObjects->getNextRootNode(); node != NULL; node = mSelectedObjects->getNextRootNode()) + BOOL first = TRUE; + LLSaleInfo sale_info; + for (LLObjectSelection::root_iterator iter = getSelection()->root_begin(); + iter != getSelection()->root_end(); iter++ ) { - if(!node->mValid) + LLSelectNode* node = *iter; + if (!node->mValid) { - valid = FALSE; - break; + return FALSE; + } + + if (first) + { + sale_info = node->mSaleInfo; + first = FALSE; + } + else + { + sale_info.accumulate(node->mSaleInfo); } - sale_info.accumulate(node->mSaleInfo); } - return valid; + + result_sale_info = sale_info; + + return TRUE; } -BOOL LLSelectMgr::selectGetAggregatePermissions(LLAggregatePermissions& ag_perm) +BOOL LLSelectMgr::selectGetAggregatePermissions(LLAggregatePermissions& result_perm) { - LLSelectNode* node = mSelectedObjects->getFirstNode(); - if (!node) return FALSE; - if (!node->mValid) return FALSE; - BOOL valid = TRUE; - ag_perm = node->mAggregatePerm; - for(node = mSelectedObjects->getNextNode(); node != NULL; node = mSelectedObjects->getNextNode()) + BOOL first = TRUE; + LLAggregatePermissions perm; + for (LLObjectSelection::root_iterator iter = getSelection()->root_begin(); + iter != getSelection()->root_end(); iter++ ) { - if(!node->mValid) + LLSelectNode* node = *iter; + if (!node->mValid) { - valid = FALSE; - break; + return FALSE; + } + + if (first) + { + perm = node->mAggregatePerm; + first = FALSE; + } + else + { + perm.aggregate(node->mAggregatePerm); } - ag_perm.aggregate(node->mAggregatePerm); } - return valid; + + result_perm = perm; + + return TRUE; } -BOOL LLSelectMgr::selectGetAggregateTexturePermissions(LLAggregatePermissions& ag_perm) +BOOL LLSelectMgr::selectGetAggregateTexturePermissions(LLAggregatePermissions& result_perm) { - LLSelectNode* node = mSelectedObjects->getFirstNode(); - if (!node) return FALSE; - if (!node->mValid) return FALSE; - BOOL valid = TRUE; - ag_perm = node->getObject()->permYouOwner() ? node->mAggregateTexturePermOwner : node->mAggregateTexturePerm; - for(node = mSelectedObjects->getNextNode(); node != NULL; node = mSelectedObjects->getNextNode()) + BOOL first = TRUE; + LLAggregatePermissions perm; + for (LLObjectSelection::root_iterator iter = getSelection()->root_begin(); + iter != getSelection()->root_end(); iter++ ) { - if(!node->mValid) + LLSelectNode* node = *iter; + if (!node->mValid) { - valid = FALSE; - break; + return FALSE; + } + + LLAggregatePermissions t_perm = node->getObject()->permYouOwner() ? node->mAggregateTexturePermOwner : node->mAggregateTexturePerm; + if (first) + { + perm = t_perm; + first = FALSE; + } + else + { + perm.aggregate(t_perm); } - ag_perm.aggregate(node->getObject()->permYouOwner() ? node->mAggregateTexturePermOwner : node->mAggregateTexturePerm); } - return valid; + + result_perm = perm; + + return TRUE; } @@ -3115,8 +2900,10 @@ void LLSelectMgr::selectDuplicate(const LLVector3& offset, BOOL select_copy) } else { - for (LLSelectNode* node = mSelectedObjects->getFirstRootNode(); node; node = mSelectedObjects->getNextRootNode()) + for (LLObjectSelection::root_iterator iter = getSelection()->root_begin(); + iter != getSelection()->root_end(); iter++ ) { + LLSelectNode* node = *iter; node->mDuplicated = TRUE; node->mDuplicatePos = node->getObject()->getPositionGlobal(); node->mDuplicateRot = node->getObject()->getRotation(); @@ -3133,21 +2920,24 @@ void LLSelectMgr::repeatDuplicate() return; } - LLSelectNode* node; - LLDynamicArray non_duplicated_objects; + std::vector non_duplicated_objects; - for (node = mSelectedObjects->getFirstRootNode(); node; node = mSelectedObjects->getNextRootNode()) + for (LLObjectSelection::root_iterator iter = getSelection()->root_begin(); + iter != getSelection()->root_end(); iter++ ) { + LLSelectNode* node = *iter; if (!node->mDuplicated) { - non_duplicated_objects.put(node->getObject()); + non_duplicated_objects.push_back(node->getObject()); } } // make sure only previously duplicated objects are selected - for (S32 i = 0; i < non_duplicated_objects.count(); i++) + for (std::vector::iterator iter = non_duplicated_objects.begin(); + iter != non_duplicated_objects.end(); ++iter) { - deselectObjectAndFamily(non_duplicated_objects[i]); + LLViewerObject* objectp = *iter; + deselectObjectAndFamily(objectp); } // duplicate objects in place @@ -3159,8 +2949,10 @@ void LLSelectMgr::repeatDuplicate() sendListToRegions("ObjectDuplicate", packDuplicateHeader, packDuplicate, &data, SEND_ONLY_ROOTS); // move current selection based on delta from duplication position and update duplication position - for (node = mSelectedObjects->getFirstRootNode(); node; node = mSelectedObjects->getNextRootNode()) + for (LLObjectSelection::root_iterator iter = getSelection()->root_begin(); + iter != getSelection()->root_end(); iter++ ) { + LLSelectNode* node = *iter; if (node->mDuplicated) { LLQuaternion cur_rot = node->getObject()->getRotation(); @@ -3380,7 +3172,7 @@ void LLSelectMgr::sendGroup(const LLUUID& group_id) struct LLBuyData { - LLDynamicArray mObjectsSent; + std::vector mObjectsSent; LLUUID mCategoryID; LLSaleInfo mSaleInfo; }; @@ -3403,9 +3195,9 @@ void LLSelectMgr::packBuyObjectIDs(LLSelectNode* node, void* data) LLBuyData* buy = (LLBuyData*)data; LLViewerObject* object = node->getObject(); - if(buy->mObjectsSent.find(object) == LLDynamicArray::FAIL) + if (std::find(buy->mObjectsSent.begin(), buy->mObjectsSent.end(), object) == buy->mObjectsSent.end()) { - buy->mObjectsSent.put(object); + buy->mObjectsSent.push_back(object); gMessageSystem->nextBlockFast(_PREHASH_ObjectData); gMessageSystem->addU32Fast(_PREHASH_ObjectLocalID, node->getObject()->getLocalID() ); gMessageSystem->addU8Fast(_PREHASH_SaleType, buy->mSaleInfo.getSaleType()); @@ -3480,7 +3272,6 @@ void LLSelectMgr::deselectAll() mLastSentSelectionCenterGlobal.clearVec(); updatePointAt(); - updateSelectionCenter(); } void LLSelectMgr::deselectUnused() @@ -3494,7 +3285,6 @@ void LLSelectMgr::deselectUnused() void LLSelectMgr::convertTransient() { - // use STL-style iteration to avoid recursive iteration problems LLObjectSelection::iterator node_it; for (node_it = mSelectedObjects->begin(); node_it != mSelectedObjects->end(); ++node_it) { @@ -3772,32 +3562,42 @@ void LLSelectMgr::packHingeHead(void *user_data) void LLSelectMgr::selectionDump() { - LLViewerObject *object; - - for (object = mSelectedObjects->getFirstObject(); object; object = mSelectedObjects->getNextObject() ) + struct f : public LLSelectedObjectFunctor { - object->dump(); - } + virtual bool apply(LLViewerObject* object) + { + object->dump(); + return true; + } + } func; + getSelection()->applyToObjects(&func); } void LLSelectMgr::saveSelectedObjectColors() { - LLSelectNode* selectNode; - for (selectNode = mSelectedObjects->getFirstNode(); selectNode; selectNode = mSelectedObjects->getNextNode() ) + struct f : public LLSelectedNodeFunctor { - selectNode->saveColors(); - } + virtual bool apply(LLSelectNode* node) + { + node->saveColors(); + return true; + } + } func; + getSelection()->applyToNodes(&func); } void LLSelectMgr::saveSelectedObjectTextures() { - LLSelectNode* selectNode; - // invalidate current selection so we update saved textures - for (selectNode = mSelectedObjects->getFirstNode(); selectNode; selectNode = mSelectedObjects->getNextNode() ) + struct f : public LLSelectedNodeFunctor { - selectNode->mValid = FALSE; - } + virtual bool apply(LLSelectNode* node) + { + node->mValid = FALSE; + return true; + } + } func; + getSelection()->applyToNodes(&func); // request object properties message to get updated permissions data sendSelect(); @@ -3808,113 +3608,95 @@ void LLSelectMgr::saveSelectedObjectTextures() // also need to know to which simulator to send update message void LLSelectMgr::saveSelectedObjectTransform(EActionType action_type) { - LLSelectNode* selectNode; - if (mSelectedObjects->isEmpty()) { // nothing selected, so nothing to save return; } - for (selectNode = mSelectedObjects->getFirstNode(); selectNode; selectNode = mSelectedObjects->getNextNode() ) + struct f : public LLSelectedNodeFunctor { - LLViewerObject* object; - object = selectNode->getObject(); - selectNode->mSavedPositionLocal = object->getPosition(); - if (object->isAttachment()) + EActionType mActionType; + f(EActionType a) : mActionType(a) {} + virtual bool apply(LLSelectNode* selectNode) { - if (object->isRootEdit()) + LLViewerObject* object = selectNode->getObject(); + selectNode->mSavedPositionLocal = object->getPosition(); + if (object->isAttachment()) { - LLXform* parent_xform = object->mDrawable->getXform()->getParent(); - if (parent_xform) + if (object->isRootEdit()) { - selectNode->mSavedPositionGlobal = gAgent.getPosGlobalFromAgent((object->getPosition() * parent_xform->getWorldRotation()) + parent_xform->getWorldPosition()); + LLXform* parent_xform = object->mDrawable->getXform()->getParent(); + if (parent_xform) + { + selectNode->mSavedPositionGlobal = gAgent.getPosGlobalFromAgent((object->getPosition() * parent_xform->getWorldRotation()) + parent_xform->getWorldPosition()); + } } + else + { + LLViewerObject* attachment_root = (LLViewerObject*)object->getParent(); + LLXform* parent_xform = attachment_root->mDrawable->getXform()->getParent(); + LLVector3 root_pos = (attachment_root->getPosition() * parent_xform->getWorldRotation()) + parent_xform->getWorldPosition(); + LLQuaternion root_rot = (attachment_root->getRotation() * parent_xform->getWorldRotation()); + selectNode->mSavedPositionGlobal = gAgent.getPosGlobalFromAgent((object->getPosition() * root_rot) + root_pos); + } + selectNode->mSavedRotation = object->getRenderRotation(); } else { - LLViewerObject* attachment_root = (LLViewerObject*)object->getParent(); - LLXform* parent_xform = attachment_root->mDrawable->getXform()->getParent(); - LLVector3 root_pos = (attachment_root->getPosition() * parent_xform->getWorldRotation()) + parent_xform->getWorldPosition(); - LLQuaternion root_rot = (attachment_root->getRotation() * parent_xform->getWorldRotation()); - selectNode->mSavedPositionGlobal = gAgent.getPosGlobalFromAgent((object->getPosition() * root_rot) + root_pos); + selectNode->mSavedPositionGlobal = object->getPositionGlobal(); + selectNode->mSavedRotation = object->getRotationRegion(); } - selectNode->mSavedRotation = object->getRenderRotation(); - } - else - { - selectNode->mSavedPositionGlobal = object->getPositionGlobal(); - selectNode->mSavedRotation = object->getRotationRegion(); - } - selectNode->mSavedScale = object->getScale(); - selectNode->saveTextureScaleRatios(); - - } + selectNode->mSavedScale = object->getScale(); + selectNode->saveTextureScaleRatios(); + return true; + } + } func(action_type); + getSelection()->applyToNodes(&func); + mSavedSelectionBBox = getBBoxOfSelection(); } -void LLSelectMgr::selectionUpdatePhysics(BOOL physics) +struct LLSelectMgrApplyFlags : public LLSelectedObjectFunctor { - LLViewerObject *object; - - for (object = mSelectedObjects->getFirstObject(); object; object = mSelectedObjects->getNextObject() ) + LLSelectMgrApplyFlags(U32 flags, BOOL state) : mFlags(flags), mState(state) {} + U32 mFlags; + BOOL mState; + virtual bool apply(LLViewerObject* object) { - if ( !object->permModify() // preemptive permissions check - || !(object->isRoot() // don't send for child objects - || object->isJointChild())) + if ( object->permModify() && // preemptive permissions check + object->isRoot() && // don't send for child objects + !object->isJointChild()) { - continue; + object->setFlags( mFlags, mState); } - object->setFlags( FLAGS_USE_PHYSICS, physics); + return true; } +}; + +void LLSelectMgr::selectionUpdatePhysics(BOOL physics) +{ + LLSelectMgrApplyFlags func( FLAGS_USE_PHYSICS, physics); + getSelection()->applyToObjects(&func); } void LLSelectMgr::selectionUpdateTemporary(BOOL is_temporary) { - LLViewerObject *object; - - for (object = mSelectedObjects->getFirstObject(); object; object = mSelectedObjects->getNextObject() ) - { - if ( !object->permModify() // preemptive permissions check - || !(object->isRoot() // don't send for child objects - || object->isJointChild())) - { - continue; - } - object->setFlags( FLAGS_TEMPORARY_ON_REZ, is_temporary); - } + LLSelectMgrApplyFlags func( FLAGS_TEMPORARY_ON_REZ, is_temporary); + getSelection()->applyToObjects(&func); } void LLSelectMgr::selectionUpdatePhantom(BOOL is_phantom) { - LLViewerObject *object; - - for (object = mSelectedObjects->getFirstObject(); object; object = mSelectedObjects->getNextObject() ) - { - if ( !object->permModify() // preemptive permissions check - || !(object->isRoot() // don't send for child objects - || object->isJointChild())) - { - continue; - } - object->setFlags( FLAGS_PHANTOM, is_phantom); - } + LLSelectMgrApplyFlags func( FLAGS_PHANTOM, is_phantom); + getSelection()->applyToObjects(&func); } void LLSelectMgr::selectionUpdateCastShadows(BOOL cast_shadows) { - LLViewerObject *object; - - for (object = mSelectedObjects->getFirstObject(); object; object = mSelectedObjects->getNextObject() ) - { - if ( !object->permModify() // preemptive permissions check - || object->isJointChild()) - { - continue; - } - object->setFlags( FLAGS_CAST_SHADOWS, cast_shadows); - } + LLSelectMgrApplyFlags func( FLAGS_CAST_SHADOWS, cast_shadows); + getSelection()->applyToObjects(&func); } @@ -4042,6 +3824,13 @@ void LLSelectMgr::packObjectClickAction(LLSelectNode* node, void *user_data) gMessageSystem->addU8("ClickAction", node->getObject()->getClickAction()); } +void LLSelectMgr::packObjectIncludeInSearch(LLSelectNode* node, void *user_data) +{ + gMessageSystem->nextBlockFast(_PREHASH_ObjectData); + gMessageSystem->addU32Fast(_PREHASH_ObjectLocalID, node->getObject()->getLocalID() ); + gMessageSystem->addBOOL("IncludeInSearch", node->getObject()->getIncludeInSearch()); +} + // static void LLSelectMgr::packObjectLocalID(LLSelectNode* node, void *) { @@ -4130,82 +3919,81 @@ void LLSelectMgr::sendListToRegions(const LLString& message_name, S32 packets_sent = 0; S32 objects_in_this_packet = 0; - //clear update override data (allow next update through) - for (node = mSelectedObjects->getFirstNode(); - node; - node = mSelectedObjects->getNextNode()) + struct f : public LLSelectedNodeFunctor { - node->mLastPositionLocal.setVec(0,0,0); - node->mLastRotation = LLQuaternion(); - node->mLastScale.setVec(0,0,0); - } + virtual bool apply(LLSelectNode* node) + { + node->mLastPositionLocal.setVec(0,0,0); + node->mLastRotation = LLQuaternion(); + node->mLastScale.setVec(0,0,0); + return true; + } + } func; + getSelection()->applyToNodes(&func); std::queue nodes_to_send; - - switch(send_type) + + struct push_all : public LLSelectedNodeFunctor { - case SEND_ONLY_ROOTS: - node = mSelectedObjects->getFirstRootNode(); - while(node) + std::queue& nodes_to_send; + push_all(std::queue& n) : nodes_to_send(n) {} + virtual bool apply(LLSelectNode* node) { nodes_to_send.push(node); - node = mSelectedObjects->getNextRootNode(); + return true; } - break; - case SEND_INDIVIDUALS: - node = mSelectedObjects->getFirstNode(); - while(node) - { - nodes_to_send.push(node); - node = mSelectedObjects->getNextNode(); - } - break; - case SEND_ROOTS_FIRST: - // first roots... - node = mSelectedObjects->getFirstNode(); - while(node) + }; + struct push_some : public LLSelectedNodeFunctor + { + std::queue& nodes_to_send; + bool mRoots; + push_some(std::queue& n, bool roots) : nodes_to_send(n), mRoots(roots) {} + virtual bool apply(LLSelectNode* node) { - if (node->getObject()->isRootEdit()) + BOOL is_root = node->getObject()->isRootEdit(); + if ((mRoots && is_root) || (!mRoots && !is_root)) { nodes_to_send.push(node); } - node = mSelectedObjects->getNextNode(); + return true; } - - // then children... - node = mSelectedObjects->getFirstNode(); - while(node) + }; + struct push_editable : public LLSelectedNodeFunctor + { + std::queue& nodes_to_send; + push_editable(std::queue& n) : nodes_to_send(n) {} + virtual bool apply(LLSelectNode* node) { - if (!node->getObject()->isRootEdit()) - { - nodes_to_send.push(node); - } - node = mSelectedObjects->getNextNode(); + + nodes_to_send.push(node); + return true; } + }; + struct push_all pushall(nodes_to_send); + struct push_some pushroots(nodes_to_send, TRUE); + struct push_some pushnonroots(nodes_to_send, FALSE); + struct push_editable pusheditable(nodes_to_send); + + switch(send_type) + { + case SEND_ONLY_ROOTS: + getSelection()->applyToRootNodes(&pusheditable); + break; + case SEND_INDIVIDUALS: + getSelection()->applyToNodes(&pushall); + break; + case SEND_ROOTS_FIRST: + // first roots... + getSelection()->applyToNodes(&pushroots); + // then children... + getSelection()->applyToNodes(&pushnonroots); break; - case SEND_CHILDREN_FIRST: + case SEND_CHILDREN_FIRST: // first children... - node = mSelectedObjects->getFirstNode(); - while(node) - { - if (!node->getObject()->isRootEdit()) - { - nodes_to_send.push(node); - } - node = mSelectedObjects->getNextNode(); - } - - // ...then roots - node = mSelectedObjects->getFirstNode(); - while(node) - { - if (node->getObject()->isRootEdit()) - { - nodes_to_send.push(node); - } - node = mSelectedObjects->getNextNode(); - } + getSelection()->applyToNodes(&pushnonroots); + // then roots... + getSelection()->applyToNodes(&pushroots); break; default: @@ -4213,8 +4001,11 @@ void LLSelectMgr::sendListToRegions(const LLString& message_name, } // bail if nothing selected - if (nodes_to_send.empty()) return; - + if (nodes_to_send.empty()) + { + return; + } + node = nodes_to_send.front(); nodes_to_send.pop(); @@ -4376,27 +4167,24 @@ void LLSelectMgr::processObjectProperties(LLMessageSystem* msg, void** user_data for (S32 buf_offset = 0; buf_offset < size; buf_offset += UUID_BYTES) { - LLUUID id; - memcpy(id.mData, packed_buffer + buf_offset, UUID_BYTES); /* Flawfinder: ignore */ - texture_ids.push_back(id); + LLUUID tid; + memcpy(tid.mData, packed_buffer + buf_offset, UUID_BYTES); /* Flawfinder: ignore */ + texture_ids.push_back(tid); } } // Iterate through nodes at end, since it can be on both the regular AND hover list - BOOL found = FALSE; - LLSelectNode* node; - for (node = gSelectMgr->mSelectedObjects->getFirstNode(); - node; - node = gSelectMgr->mSelectedObjects->getNextNode()) + struct f : public LLSelectedNodeFunctor { - if (node->getObject()->mID == id) + LLUUID mID; + f(const LLUUID& id) : mID(id) {} + virtual bool apply(LLSelectNode* node) { - found = TRUE; - break; + return (node->getObject()->mID == mID); } - } - + } func(id); + LLSelectNode* node = gSelectMgr->getSelection()->getFirstNode(&func); if (node) { @@ -4529,23 +4317,21 @@ void LLSelectMgr::processObjectPropertiesFamily(LLMessageSystem* msg, void** use LLString fullname(first_name); fullname.append(" "); fullname.append(last_name); - reporterp->setPickedObjectProperties(name, fullname.c_str(), owner_id); + reporterp->setPickedObjectProperties(name, fullname, owner_id); } } // Now look through all of the hovered nodes - BOOL found = FALSE; - LLSelectNode* node; - for (node = gSelectMgr->mHoverObjects->getFirstNode(); - node; - node = gSelectMgr->mHoverObjects->getNextNode()) + struct f : public LLSelectedNodeFunctor { - if (node->getObject()->mID == id) + LLUUID mID; + f(const LLUUID& id) : mID(id) {} + virtual bool apply(LLSelectNode* node) { - found = TRUE; - break; + return (node->getObject()->mID == mID); } - } + } func(id); + LLSelectNode* node = gSelectMgr->getHoverObjects()->getFirstNode(&func); if (node) { @@ -4577,7 +4363,7 @@ void LLSelectMgr::processForceObjectSelect(LLMessageSystem* msg, void**) LLUUID full_id; S32 local_id; LLViewerObject* object; - LLDynamicArray objects; + std::vector objects; S32 i; S32 block_count = msg->getNumberOfBlocks("Data"); @@ -4592,7 +4378,7 @@ void LLSelectMgr::processForceObjectSelect(LLMessageSystem* msg, void**) object = gObjectList.findObject(full_id); if (object) { - objects.put(object); + objects.push_back(object); } } @@ -4605,7 +4391,6 @@ extern LLGLdouble gGLModelView[16]; void LLSelectMgr::updateSilhouettes() { - LLSelectNode *node; S32 num_sils_genned = 0; LLVector3d cameraPos = gAgent.getCameraPositionGlobal(); @@ -4618,21 +4403,24 @@ void LLSelectMgr::updateSilhouettes() mSilhouetteImagep = gImageList.getImage(id, TRUE, TRUE); } + mHighlightedObjects->cleanupNodes(); if((cameraPos - mLastCameraPos).magVecSquared() > SILHOUETTE_UPDATE_THRESHOLD_SQUARED * currentCameraZoom * currentCameraZoom) { - for (node = mSelectedObjects->getFirstNode(); node; node = mSelectedObjects->getNextNode() ) + struct f : public LLSelectedObjectFunctor { - if (node->getObject()) + virtual bool apply(LLViewerObject* object) { - node->getObject()->setChanged(LLXform::SILHOUETTE); + object->setChanged(LLXform::SILHOUETTE); + return true; } - } + } func; + getSelection()->applyToObjects(&func); mLastCameraPos = gAgent.getCameraPositionGlobal(); } - LLDynamicArray changed_objects; + std::vector changed_objects; if (mSelectedObjects->getNumNodes()) { @@ -4643,8 +4431,10 @@ void LLSelectMgr::updateSilhouettes() for (S32 pass = 0; pass < 2; pass++) { - for (node = mSelectedObjects->getFirstNode(); node; node = mSelectedObjects->getNextNode() ) + for (LLObjectSelection::iterator iter = mSelectedObjects->begin(); + iter != mSelectedObjects->end(); iter++) { + LLSelectNode* node = *iter; LLViewerObject* objectp = node->getObject(); // do roots first, then children so that root flags are cleared ASAP @@ -4662,7 +4452,7 @@ void LLSelectMgr::updateSilhouettes() if (num_sils_genned++ < MAX_SILS_PER_FRAME)// && objectp->mDrawable->isVisible()) { generateSilhouette(node, gCamera->getOrigin()); - changed_objects.put(objectp); + changed_objects.push_back(objectp); } else if (objectp->isAttachment()) { @@ -4711,20 +4501,23 @@ void LLSelectMgr::updateSilhouettes() } // remove highlight nodes not in roots list - LLDynamicArray remove_these_nodes; - LLDynamicArray remove_these_roots; - for (LLSelectNode* nodep = mHighlightedObjects->getFirstNode(); nodep; nodep = mHighlightedObjects->getNextNode()) + std::vector remove_these_nodes; + std::vector remove_these_roots; + + for (LLObjectSelection::iterator iter = mHighlightedObjects->begin(); + iter != mHighlightedObjects->end(); iter++) { - LLViewerObject* objectp = nodep->getObject(); + LLSelectNode* node = *iter; + LLViewerObject* objectp = node->getObject(); if (objectp->isRoot() || !select_linked_set) { if (roots.count(objectp) == 0) { - remove_these_nodes.put(nodep); + remove_these_nodes.push_back(node); } else { - remove_these_roots.put(objectp); + remove_these_roots.push_back(objectp); } } else @@ -4733,22 +4526,25 @@ void LLSelectMgr::updateSilhouettes() if (roots.count(rootp) == 0) { - remove_these_nodes.put(nodep); + remove_these_nodes.push_back(node); } } } // remove all highlight nodes no longer in rectangle selection - S32 i; - for (i = 0; i < remove_these_nodes.count(); i++) + for (std::vector::iterator iter = remove_these_nodes.begin(); + iter != remove_these_nodes.end(); ++iter) { - mHighlightedObjects->removeNode(remove_these_nodes[i]); + LLSelectNode* nodep = *iter; + mHighlightedObjects->removeNode(nodep); } // remove all root objects already being highlighted - for (i = 0; i < remove_these_roots.count(); i++) + for (std::vector::iterator iter = remove_these_roots.begin(); + iter != remove_these_roots.end(); ++iter) { - roots.erase(remove_these_roots[i]); + LLViewerObject* objectp = *iter; + roots.erase(objectp); } // add all new objects in rectangle selection @@ -4756,36 +4552,38 @@ void LLSelectMgr::updateSilhouettes() iter != roots.end(); iter++) { LLViewerObject* objectp = *iter; - LLSelectNode* rect_select_node = new LLSelectNode(objectp, TRUE); - rect_select_node->selectAllTEs(TRUE); + LLSelectNode* rect_select_root_node = new LLSelectNode(objectp, TRUE); + rect_select_root_node->selectAllTEs(TRUE); if (!canSelectObject(objectp)) { continue; } - mHighlightedObjects->addNode(rect_select_node); - if (!select_linked_set) { - rect_select_node->mIndividualSelection = TRUE; + rect_select_root_node->mIndividualSelection = TRUE; } else { - for (U32 i = 0; i < objectp->mChildList.size(); i++) + for (LLViewerObject::child_list_t::iterator iter = objectp->mChildList.begin(); + iter != objectp->mChildList.end(); ++iter) { - LLViewerObject* child_objectp = objectp->mChildList[i]; - + LLViewerObject* child_objectp = *iter; + if (!canSelectObject(child_objectp)) { continue; } - rect_select_node = new LLSelectNode(objectp->mChildList[i], TRUE); + LLSelectNode* rect_select_node = new LLSelectNode(child_objectp, TRUE); rect_select_node->selectAllTEs(TRUE); - mHighlightedObjects->addNode(rect_select_node); + mHighlightedObjects->addNodeAtEnd(rect_select_node); } } + + // Add the root last, to preserve order for link operations. + mHighlightedObjects->addNodeAtEnd(rect_select_root_node); } num_sils_genned = 0; @@ -4794,8 +4592,10 @@ void LLSelectMgr::updateSilhouettes() //BOOL subtracting_from_selection = (gKeyboard->currentMask(TRUE) == MASK_CONTROL); for (S32 pass = 0; pass < 2; pass++) { - for (node = mHighlightedObjects->getFirstNode(); node; node = mHighlightedObjects->getNextNode() ) + for (LLObjectSelection::iterator iter = mHighlightedObjects->begin(); + iter != mHighlightedObjects->end(); iter++) { + LLSelectNode* node = *iter; LLViewerObject* objectp = node->getObject(); // do roots first, then children so that root flags are cleared ASAP @@ -4813,7 +4613,7 @@ void LLSelectMgr::updateSilhouettes() if (num_sils_genned++ < MAX_SILS_PER_FRAME) { generateSilhouette(node, gCamera->getOrigin()); - changed_objects.put(objectp); + changed_objects.push_back(objectp); } else if (objectp->isAttachment() && objectp->getRootEdit()->mDrawable.notNull()) { @@ -4846,10 +4646,12 @@ void LLSelectMgr::updateSilhouettes() mHighlightedObjects->deleteAllNodes(); } - for (S32 i = 0; i < changed_objects.count(); i++) + for (std::vector::iterator iter = changed_objects.begin(); + iter != changed_objects.end(); ++iter) { // clear flags after traversing node list (as child objects need to refer to parent flags, etc) - changed_objects[i]->clearChanged(LLXform::MOVED | LLXform::SILHOUETTE); + LLViewerObject* objectp = *iter; + objectp->clearChanged(LLXform::MOVED | LLXform::SILHOUETTE); } //glAlphaFunc(GL_GREATER, 0.01f); @@ -4862,8 +4664,7 @@ void LLSelectMgr::renderSilhouettes(BOOL for_hud) return; } - LLSelectNode *node; - LLViewerImage::bindTexture(gSelectMgr->mSilhouetteImagep); + LLViewerImage::bindTexture(mSilhouetteImagep); LLGLSPipelineSelection gls_select; glAlphaFunc(GL_GREATER, 0.0f); LLGLEnable blend(GL_BLEND); @@ -4895,8 +4696,10 @@ void LLSelectMgr::renderSilhouettes(BOOL for_hud) LLUUID inspect_item_id = LLFloaterInspect::getSelectedUUID(); for (S32 pass = 0; pass < 2; pass++) { - for (node = mSelectedObjects->getFirstNode(); node; node = mSelectedObjects->getNextNode() ) + for (LLObjectSelection::iterator iter = mSelectedObjects->begin(); + iter != mSelectedObjects->end(); iter++) { + LLSelectNode* node = *iter; LLViewerObject* objectp = node->getObject(); if (objectp->isHUDAttachment() != for_hud) { @@ -4931,8 +4734,10 @@ void LLSelectMgr::renderSilhouettes(BOOL for_hud) BOOL subtracting_from_selection = (gKeyboard->currentMask(TRUE) == MASK_CONTROL); for (S32 pass = 0; pass < 2; pass++) { - for (node = mHighlightedObjects->getFirstNode(); node; node = mHighlightedObjects->getNextNode() ) + for (LLObjectSelection::iterator iter = mHighlightedObjects->begin(); + iter != mHighlightedObjects->end(); iter++) { + LLSelectNode* node = *iter; LLViewerObject* objectp = node->getObject(); if (objectp->isHUDAttachment() != for_hud) { @@ -4962,7 +4767,7 @@ void LLSelectMgr::renderSilhouettes(BOOL for_hud) stop_glerror(); } - gSelectMgr->mSilhouetteImagep->unbindTexture(0, GL_TEXTURE_2D); + mSilhouetteImagep->unbindTexture(0, GL_TEXTURE_2D); glAlphaFunc(GL_GREATER, 0.01f); } @@ -5091,7 +4896,7 @@ S32 LLSelectNode::getLastSelectedTE() return mLastTESelected; } -LLViewerObject *LLSelectNode::getObject() +LLViewerObject* LLSelectNode::getObject() { if (!mObject) { @@ -5104,6 +4909,11 @@ LLViewerObject *LLSelectNode::getObject() return mObject; } +void LLSelectNode::setObject(LLViewerObject* object) +{ + mObject = object; +} + void LLSelectNode::saveColors() { if (mObject.notNull()) @@ -5123,8 +4933,8 @@ void LLSelectNode::saveTextures(const std::vector& textures) { mSavedTextures.clear(); - std::vector::const_iterator texture_it; - for (texture_it = textures.begin(); texture_it != textures.end(); ++texture_it) + for (std::vector::const_iterator texture_it = textures.begin(); + texture_it != textures.end(); ++texture_it) { mSavedTextures.push_back(*texture_it); } @@ -5144,7 +4954,7 @@ void LLSelectNode::saveTextureScaleRatios() U32 s_axis = 0; U32 t_axis = 0; - gSelectMgr->getTESTAxes(mObject, i, &s_axis, &t_axis); + LLPrimitive::getTESTAxes(i, &s_axis, &t_axis); LLVector3 v; LLVector3 scale = mObject->getScale(); @@ -5440,9 +5250,10 @@ S32 get_family_count(LLViewerObject *parent) llwarns << "Trying to get_family_count on null parent!" << llendl; } S32 count = 1; // for this object - for (U32 i = 0; i < parent->mChildList.size(); i++) + for (LLViewerObject::child_list_t::iterator iter = parent->mChildList.begin(); + iter != parent->mChildList.end(); ++iter) { - LLViewerObject* child = parent->mChildList[i]; + LLViewerObject* child = *iter; if (!child) { @@ -5473,7 +5284,7 @@ void LLSelectMgr::updateSelectionCenter() //override any object updates received //for selected objects - gSelectMgr->overrideObjectUpdates(); + overrideObjectUpdates(); LLViewerObject* object = mSelectedObjects->getFirstObject(); if (!object) @@ -5484,11 +5295,8 @@ void LLSelectMgr::updateSelectionCenter() mShowSelection = FALSE; mSelectionBBox = LLBBox(); mPauseRequest = NULL; - if (gAgent.getAvatarObject()) - { - gAgent.getAvatarObject()->mHUDTargetZoom = 1.f; - gAgent.getAvatarObject()->mHUDCurZoom = 1.f; - } + resetAgentHUDZoom(); + } else { @@ -5517,10 +5325,13 @@ void LLSelectMgr::updateSelectionCenter() LLVector3d select_center; // keep a list of jointed objects for showing the joint HUDEffects - LLDynamicArray < LLViewerObject *> jointed_objects; + std::vector < LLViewerObject *> jointed_objects; - for (object = mSelectedObjects->getFirstObject(); object; object = mSelectedObjects->getNextObject() ) + for (LLObjectSelection::iterator iter = mSelectedObjects->begin(); + iter != mSelectedObjects->end(); iter++) { + LLSelectNode* node = *iter; + LLViewerObject* object = node->getObject(); LLViewerObject *myAvatar = gAgent.getAvatarObject(); LLViewerObject *root = object->getRootEdit(); if (mSelectedObjects->mSelectType == SELECT_TYPE_WORLD && // not an attachment @@ -5534,9 +5345,9 @@ void LLSelectMgr::updateSelectionCenter() if (object->isJointChild()) { - jointed_objects.put(object); + jointed_objects.push_back(object); } - } // end for + } LLVector3 bbox_center_agent = bbox.getCenterAgent(); mSelectionCenterGlobal = gAgent.getPosGlobalFromAgent(bbox_center_agent); @@ -5666,6 +5477,7 @@ void LLSelectMgr::redo() //----------------------------------------------------------------------------- BOOL LLSelectMgr::canDoDelete() { + // Note: Can only delete root objects (see getFirstDeleteableObject() for more info) return mSelectedObjects->getFirstDeleteableObject() != NULL; } @@ -5730,14 +5542,18 @@ ESelectType LLSelectMgr::getSelectTypeForObject(LLViewerObject* object) void LLSelectMgr::validateSelection() { - LLViewerObject* objectp; - for (objectp = mSelectedObjects->getFirstObject(); objectp; objectp = mSelectedObjects->getNextObject()) + struct f : public LLSelectedObjectFunctor { - if (!canSelectObject(objectp)) + virtual bool apply(LLViewerObject* object) { - deselectObjectOnly(objectp); + if (!gSelectMgr->canSelectObject(object)) + { + gSelectMgr->deselectObjectOnly(object); + } + return true; } - } + } func; + getSelection()->applyToObjects(&func); } BOOL LLSelectMgr::canSelectObject(LLViewerObject* object) @@ -5752,445 +5568,140 @@ BOOL LLSelectMgr::canSelectObject(LLViewerObject* object) { // only select my own objects return FALSE; - } - - // Can't select dead objects - if (object->isDead()) return FALSE; - - // Can't select orphans - if (object->isOrphaned()) return FALSE; - - // Can't select avatars - if (object->isAvatar()) return FALSE; - - // Can't select land - if (object->getPCode() == LLViewerObject::LL_VO_SURFACE_PATCH) return FALSE; - - ESelectType selection_type = getSelectTypeForObject(object); - if (mSelectedObjects->getObjectCount() > 0 && mSelectedObjects->mSelectType != selection_type) return FALSE; - - return TRUE; -} - -BOOL LLSelectMgr::setForceSelection(BOOL force) -{ - std::swap(mForceSelection,force); - return force; -} - -LLObjectSelection::LLObjectSelection() : - std::list(), - LLRefCount(), - mCurrentNode(end()), - mCurrentTE(-1), - mSelectType(SELECT_TYPE_WORLD) -{ -} - -LLObjectSelection::~LLObjectSelection() -{ - std::for_each(begin(), end(), DeletePointer()); -} - -void LLObjectSelection::updateEffects() -{ -} - -S32 LLObjectSelection::getNumNodes() -{ - return size(); -} - -void LLObjectSelection::addNode(LLSelectNode *nodep) -{ - push_front(nodep); - mSelectNodeMap[nodep->getObject()] = nodep; -} - -void LLObjectSelection::addNodeAtEnd(LLSelectNode *nodep) -{ - push_back(nodep); - mSelectNodeMap[nodep->getObject()] = nodep; -} - -void LLObjectSelection::removeNode(LLSelectNode *nodep) -{ - std::list::iterator iter = begin(); - while(iter != end()) - { - if ((*iter) == nodep) - { - mSelectNodeMap.erase(nodep->getObject()); - iter = erase(iter); - } - else - { - ++iter; - } - } -} - -void LLObjectSelection::deleteAllNodes() -{ - std::for_each(begin(), end(), DeletePointer()); - clear(); - mSelectNodeMap.clear(); -} - -LLSelectNode* LLObjectSelection::findNode(LLViewerObject* objectp) -{ - std::map, LLSelectNode*>::iterator found_it = mSelectNodeMap.find(objectp); - if (found_it != mSelectNodeMap.end()) - { - return found_it->second; - } - return NULL; -} - -//----------------------------------------------------------------------------- -// getFirstNode() -//----------------------------------------------------------------------------- -LLSelectNode *LLObjectSelection::getFirstNode() -{ - mCurrentNode = begin();//getFirstData(); - - while (mCurrentNode != end() && !(*mCurrentNode)->getObject()) - { - // The object on this was killed at some point, delete it. - erase(mCurrentNode++); - } - - if (mCurrentNode != end()) - { - return *mCurrentNode; - } - - return NULL; -} - -//----------------------------------------------------------------------------- -// getCurrentNode() -//----------------------------------------------------------------------------- -LLSelectNode *LLObjectSelection::getCurrentNode() -{ - while (mCurrentNode != end() && !(*mCurrentNode)->getObject()) - { - // The object on this was killed at some point, delete it. - erase(mCurrentNode++); - } - - if (mCurrentNode != end()) - { - return *mCurrentNode; - } - return NULL; -} - -//----------------------------------------------------------------------------- -// getNextNode() -//----------------------------------------------------------------------------- -LLSelectNode *LLObjectSelection::getNextNode() -{ - ++mCurrentNode; - - while (mCurrentNode != end() && !(*mCurrentNode)->getObject()) - { - // The object on this was killed at some point, delete it. - erase(mCurrentNode++); - } - - if (mCurrentNode != end()) - { - return *mCurrentNode; - } - return NULL; -} - - - -//----------------------------------------------------------------------------- -// getFirstObject() -//----------------------------------------------------------------------------- -LLViewerObject* LLObjectSelection::getFirstObject() -{ - mCurrentNode = begin(); - - while (mCurrentNode != end() && !(*mCurrentNode)->getObject()) - { - // The object on this was killed at some point, delete it. - erase(mCurrentNode++); - } - - if (mCurrentNode != end()) - { - return (*mCurrentNode)->getObject(); - } - - return NULL; -} - - -//----------------------------------------------------------------------------- -// getNextObject() -//----------------------------------------------------------------------------- -LLViewerObject* LLObjectSelection::getNextObject() -{ - ++mCurrentNode;// = getNextData(); - - while (mCurrentNode != end() && !(*mCurrentNode)->getObject()) - { - // The object on this was killed at some point, delete it. - erase(mCurrentNode++); - } - - if (mCurrentNode != end()) - { - return (*mCurrentNode)->getObject(); - } - - return NULL; -} - - - -//----------------------------------------------------------------------------- -// getPrimaryTE() -//----------------------------------------------------------------------------- -void LLObjectSelection::getPrimaryTE(LLViewerObject* *object, S32 *te) -{ - // initialize object and te - *te = 0; - *object = NULL; - - BOOL searching_roots = TRUE; - - // try for root node first, then first child node - LLSelectNode *primary_node = getFirstNode(); //getFirstRootNode(); - if (!primary_node) - { - primary_node = getFirstNode(); - searching_roots = FALSE; - } - - while (primary_node) - { - S32 last_selected_te = primary_node->getLastSelectedTE(); - if (last_selected_te >= 0) - { - *object = primary_node->getObject(); - *te = last_selected_te; - return; - } - for(S32 cur_te = 0; cur_te < primary_node->getObject()->getNumTEs(); cur_te++) - { - // if face selected - if (primary_node->isTESelected(cur_te)) - { - // return this object and face - *object = primary_node->getObject(); - *te = cur_te; - return; - } - } - if (searching_roots) - { - primary_node = getNextRootNode(); - if (!primary_node) - { - primary_node = getFirstNode(); - searching_roots = FALSE; - } - } - else - { - primary_node = getNextNode(); - } - } -} - -//----------------------------------------------------------------------------- -// getFirstTE() -//----------------------------------------------------------------------------- -void LLObjectSelection::getFirstTE(LLViewerObject* *object, S32 *te) -{ - // start with first face - mCurrentTE = 0; - - LLSelectNode *cur_node = getFirstNode(); - - // repeat over all selection nodes - while (cur_node) - { - // skip objects with no faces - if (cur_node->getObject()->getNumTEs() == 0) - { - mCurrentTE = 0; - cur_node = getNextNode(); - continue; - } - - // repeat over all faces for this object - while (mCurrentTE < cur_node->getObject()->getNumTEs()) - { - // if face selected - if (cur_node->isTESelected(mCurrentTE)) - { - // return this object and face - *object = cur_node->getObject(); - *te = mCurrentTE; - return; - } + } - mCurrentTE++; - } + // Can't select dead objects + if (object->isDead()) return FALSE; + + // Can't select orphans + if (object->isOrphaned()) return FALSE; + + // Can't select avatars + if (object->isAvatar()) return FALSE; - // Couldn't find a selected face. - // This can happen if an object's volume parameters are changed in such a way - // that texture entries are eliminated. - // - // TODO: Consider selecting all faces in this case? Subscribe the selection - // list to the volume changing code? + // Can't select land + if (object->getPCode() == LLViewerObject::LL_VO_SURFACE_PATCH) return FALSE; - mCurrentTE = 0; - cur_node = getNextNode(); - } + ESelectType selection_type = getSelectTypeForObject(object); + if (mSelectedObjects->getObjectCount() > 0 && mSelectedObjects->mSelectType != selection_type) return FALSE; - // The list doesn't contain any nodes. Return NULL. - *object = NULL; - *te = -1; - return; + return TRUE; } +BOOL LLSelectMgr::setForceSelection(BOOL force) +{ + std::swap(mForceSelection,force); + return force; +} -//----------------------------------------------------------------------------- -// getNextFace() -//----------------------------------------------------------------------------- -void LLObjectSelection::getNextTE(LLViewerObject* *object, S32 *te) +void LLSelectMgr::resetAgentHUDZoom() { - // try next face - mCurrentTE++; - - LLSelectNode *cur_node = getCurrentNode(); - // repeat over remaining selection nodes - while ( cur_node ) + if (gAgent.getAvatarObject()) { - // skip objects with no faces - if (cur_node->getObject()->getNumTEs() == 0) - { - mCurrentTE = 0; - cur_node = getNextNode(); - continue; - } - - // repeat over all faces for this object - // CRO: getNumTEs() no longer equals mFaces.count(), so use mFaces.count() instead - while ( mCurrentTE < cur_node->getObject()->getNumTEs() ) - { - // if face selected - if (cur_node->isTESelected(mCurrentTE)) - { - // return this object and face - *object = cur_node->getObject(); - *te = mCurrentTE; - return; - } - - mCurrentTE++; - } - - mCurrentTE = 0; - cur_node = getNextNode(); + gAgent.getAvatarObject()->mHUDTargetZoom = 1.f; + gAgent.getAvatarObject()->mHUDCurZoom = 1.f; } - - // The list doesn't contain any nodes. Return NULL. - *object = NULL; - *te = -1; - return; } -void LLObjectSelection::getCurrentTE(LLViewerObject* *object, S32 *te) +void LLSelectMgr::getAgentHUDZoom(F32 &target_zoom, F32 ¤t_zoom) const { - if (mCurrentNode != end()) - { - *object = (*mCurrentNode)->getObject(); - *te = mCurrentTE; - } - else + if (gAgent.getAvatarObject()) { - *object = NULL; - *te = -1; + target_zoom = gAgent.getAvatarObject()->mHUDTargetZoom; + current_zoom = gAgent.getAvatarObject()->mHUDCurZoom; } } -//----------------------------------------------------------------------------- -// getFirstRootNode() -//----------------------------------------------------------------------------- -LLSelectNode *LLObjectSelection::getFirstRootNode() -{ - LLSelectNode *cur_node = getFirstNode(); - // scan through child objects and roots set to ignore - while (cur_node && - (!(cur_node->getObject()->isRootEdit() || cur_node->getObject()->isJointChild()) || - cur_node->mIndividualSelection)) +void LLSelectMgr::setAgentHUDZoom(F32 target_zoom, F32 current_zoom) +{ + if (gAgent.getAvatarObject()) { - cur_node = getNextNode(); + gAgent.getAvatarObject()->mHUDTargetZoom = target_zoom; + gAgent.getAvatarObject()->mHUDCurZoom = current_zoom; } - - return cur_node; } +LLObjectSelection::LLObjectSelection() : + LLRefCount(), + mSelectType(SELECT_TYPE_WORLD) +{ +} -//----------------------------------------------------------------------------- -// getNextRootNode() -//----------------------------------------------------------------------------- -LLSelectNode *LLObjectSelection::getNextRootNode() +LLObjectSelection::~LLObjectSelection() { - LLSelectNode *cur_node = getNextNode(); + deleteAllNodes(); +} - while (cur_node && - (!(cur_node->getObject()->isRootEdit() || cur_node->getObject()->isJointChild()) || - cur_node->mIndividualSelection)) +void LLObjectSelection::cleanupNodes() +{ + for (list_t::iterator iter = mList.begin(); iter != mList.end(); ) { - cur_node = getNextNode(); + list_t::iterator curiter = iter++; + LLSelectNode* node = *curiter; + if (node->getObject() == NULL || node->getObject()->isDead()) + { + mList.erase(curiter); + delete node; + } } - - return cur_node; } +void LLObjectSelection::updateEffects() +{ +} -//----------------------------------------------------------------------------- -// getFirstRootObject() -//----------------------------------------------------------------------------- -LLViewerObject *LLObjectSelection::getFirstRootObject() +S32 LLObjectSelection::getNumNodes() { - LLSelectNode *node = getFirstRootNode(); + return mList.size(); +} - if (node) - { - return node->getObject(); - } - else - { - return NULL; - } +void LLObjectSelection::addNode(LLSelectNode *nodep) +{ + llassert_always(nodep->getObject() && !nodep->getObject()->isDead()); + mList.push_front(nodep); + mSelectNodeMap[nodep->getObject()] = nodep; } +void LLObjectSelection::addNodeAtEnd(LLSelectNode *nodep) +{ + llassert_always(nodep->getObject() && !nodep->getObject()->isDead()); + mList.push_back(nodep); + mSelectNodeMap[nodep->getObject()] = nodep; +} -//----------------------------------------------------------------------------- -// getNextRootObject() -//----------------------------------------------------------------------------- -LLViewerObject *LLObjectSelection::getNextRootObject() +void LLObjectSelection::moveNodeToFront(LLSelectNode *nodep) { - LLSelectNode *node = getNextRootNode(); + mList.remove(nodep); + mList.push_front(nodep); +} - if (node) +void LLObjectSelection::removeNode(LLSelectNode *nodep) +{ + mSelectNodeMap.erase(nodep->getObject()); + if (nodep->getObject() == mPrimaryObject) { - return node->getObject(); + mPrimaryObject = NULL; } - else + nodep->setObject(NULL); // Will get erased in cleanupNodes() + mList.remove(nodep); +} + +void LLObjectSelection::deleteAllNodes() +{ + std::for_each(mList.begin(), mList.end(), DeletePointer()); + mList.clear(); + mSelectNodeMap.clear(); + mPrimaryObject = NULL; +} + +LLSelectNode* LLObjectSelection::findNode(LLViewerObject* objectp) +{ + std::map, LLSelectNode*>::iterator found_it = mSelectNodeMap.find(objectp); + if (found_it != mSelectNodeMap.end()) { - return NULL; + return found_it->second; } + return NULL; } //----------------------------------------------------------------------------- @@ -6198,7 +5709,7 @@ LLViewerObject *LLObjectSelection::getNextRootObject() //----------------------------------------------------------------------------- BOOL LLObjectSelection::isEmpty() { - return (size() == 0); + return (mList.size() == 0); } //----------------------------------------------------------------------------- @@ -6206,24 +5717,20 @@ BOOL LLObjectSelection::isEmpty() //----------------------------------------------------------------------------- BOOL LLObjectSelection::getOwnershipCost(S32 &cost) { - S32 count = 0; - for( LLSelectNode* nodep = getFirstNode(); nodep; nodep = getNextNode() ) - { - count++; - } - + S32 count = getObjectCount(); cost = count * OWNERSHIP_COST_PER_OBJECT; - return (count > 0); } //----------------------------------------------------------------------------- -// getObjectCount() +// getObjectCount() - returns number of non null objects //----------------------------------------------------------------------------- S32 LLObjectSelection::getObjectCount() { - return getNumNodes(); + cleanupNodes(); + S32 count = mList.size(); + return count; } @@ -6233,23 +5740,19 @@ S32 LLObjectSelection::getObjectCount() S32 LLObjectSelection::getTECount() { S32 count = 0; - - LLSelectNode* nodep; - for (nodep = getFirstNode(); nodep; nodep = getNextNode() ) + for (LLObjectSelection::iterator iter = begin(); iter != end(); iter++) { - if (nodep->getObject()) + LLSelectNode* node = *iter; + LLViewerObject* object = node->getObject(); + S32 num_tes = object->getNumTEs(); + for (S32 te = 0; te < num_tes; te++) { - S32 num_tes = nodep->getObject()->getNumTEs(); - for (S32 te = 0; te < num_tes; te++) + if (node->isTESelected(te)) { - if (nodep->isTESelected(te)) - { - count++; - } + ++count; } } } - return count; } @@ -6258,47 +5761,97 @@ S32 LLObjectSelection::getTECount() //----------------------------------------------------------------------------- S32 LLObjectSelection::getRootObjectCount() { - LLSelectNode *nodep; - S32 count = 0; - for(nodep = getFirstRootNode(); nodep; nodep = getNextRootNode()) + for (LLObjectSelection::root_iterator iter = root_begin(); iter != root_end(); iter++) { ++count; } return count; } -bool LLObjectSelection::applyToObjects(LLSelectedObjectFunctor* func) +bool LLObjectSelection::applyToObjects(LLSelectedObjectFunctor* func, bool firstonly) { - bool result = true; - LLViewerObject* object; - for (object = getFirstObject(); object != NULL; object = getNextObject()) + bool result = firstonly ? false : true; + for (iterator iter = begin(); iter != end(); ) { - result = result && func->apply(object); + iterator nextiter = iter++; + LLViewerObject* object = (*nextiter)->getObject(); + bool r = func->apply(object); + if (firstonly && r) + return true; + else + result = result && r; } return result; } -bool LLObjectSelection::applyToRootObjects(LLSelectedObjectFunctor* func) +bool LLObjectSelection::applyToRootObjects(LLSelectedObjectFunctor* func, bool firstonly) { - bool result = true; - LLViewerObject* object; - for (object = getFirstRootObject(); - object != NULL; - object = getNextRootObject()) + bool result = firstonly ? false : true; + for (root_iterator iter = root_begin(); iter != root_end(); ) { - result = result && func->apply(object); + root_iterator nextiter = iter++; + LLViewerObject* object = (*nextiter)->getObject(); + bool r = func->apply(object); + if (firstonly && r) + return true; + else + result = result && r; } return result; } -bool LLObjectSelection::applyToNodes(LLSelectedNodeFunctor *func) +bool LLObjectSelection::applyToTEs(LLSelectedTEFunctor* func, bool firstonly) { - bool result = true; - LLSelectNode* node; - for (node = getFirstNode(); node != NULL; node = getNextNode()) + bool result = firstonly ? false : true; + for (iterator iter = begin(); iter != end(); ) + { + iterator nextiter = iter++; + LLSelectNode* node = *nextiter; + LLViewerObject* object = (*nextiter)->getObject(); + for (S32 te = 0; te < object->getNumTEs(); ++te) + { + if (node->isTESelected(te)) + { + bool r = func->apply(object, te); + if (firstonly && r) + return true; + else + result = result && r; + } + } + } + return result; +} + +bool LLObjectSelection::applyToNodes(LLSelectedNodeFunctor *func, bool firstonly) +{ + bool result = firstonly ? false : true; + for (iterator iter = begin(); iter != end(); ) { - result = result && func->apply(node); + iterator nextiter = iter++; + LLSelectNode* node = *nextiter; + bool r = func->apply(node); + if (firstonly && r) + return true; + else + result = result && r; + } + return result; +} + +bool LLObjectSelection::applyToRootNodes(LLSelectedNodeFunctor *func, bool firstonly) +{ + bool result = firstonly ? false : true; + for (root_iterator iter = root_begin(); iter != root_end(); ) + { + root_iterator nextiter = iter++; + LLSelectNode* node = *nextiter; + bool r = func->apply(node); + if (firstonly && r) + return true; + else + result = result && r; } return result; } @@ -6317,12 +5870,13 @@ BOOL LLObjectSelection::contains(LLViewerObject* object) //----------------------------------------------------------------------------- BOOL LLObjectSelection::contains(LLViewerObject* object, S32 te) { - LLSelectNode *nodep; if (te == SELECT_ALL_TES) { // ...all faces - for (nodep = getFirstNode(); nodep; nodep = getNextNode() ) + for (LLObjectSelection::iterator iter = begin(); + iter != end(); iter++) { + LLSelectNode* nodep = *iter; if (nodep->getObject() == object) { BOOL all_selected = TRUE; @@ -6338,8 +5892,9 @@ BOOL LLObjectSelection::contains(LLViewerObject* object, S32 te) else { // ...one face - for (nodep = getFirstNode(); nodep; nodep = getNextNode() ) + for (LLObjectSelection::iterator iter = begin(); iter != end(); iter++) { + LLSelectNode* nodep = *iter; if (nodep->getObject() == object && nodep->isTESelected(te)) { return TRUE; @@ -6356,203 +5911,193 @@ BOOL LLObjectSelection::isAttachment() } //----------------------------------------------------------------------------- -// getFirstMoveableNode() +// getSelectedParentObject() //----------------------------------------------------------------------------- -LLSelectNode* LLObjectSelection::getFirstMoveableNode(BOOL get_root) +LLViewerObject* getSelectedParentObject(LLViewerObject *object) { - LLSelectNode* selectNode = NULL; - - if (get_root) + LLViewerObject *parent; + while (object && (parent = (LLViewerObject*)object->getParent())) { - for(selectNode = getFirstRootNode(); selectNode; selectNode = getNextRootNode()) + if (parent->isSelected()) { - if( selectNode->getObject()->permMove() ) - { - return selectNode; - break; - } + object = parent; } - } - for(selectNode = getFirstNode(); selectNode; selectNode = getNextNode()) - { - if( selectNode->getObject()->permMove() ) + else { - return selectNode; break; } } - - return NULL; + return object; } //----------------------------------------------------------------------------- -// getFirstCopyableObject() +// getFirstNode //----------------------------------------------------------------------------- -LLViewerObject* LLObjectSelection::getFirstCopyableObject(BOOL get_root) +LLSelectNode* LLObjectSelection::getFirstNode(LLSelectedNodeFunctor* func) { - LLViewerObject* object = NULL; - for(LLViewerObject* cur = getFirstObject(); cur; cur = getNextObject()) + for (iterator iter = begin(); iter != end(); ++iter) { - if( cur->permCopy() && !cur->isAttachment()) + LLSelectNode* node = *iter; + if (func == NULL || func->apply(node)) { - object = cur; - break; + return node; } - } + } + return NULL; +} - if (get_root && object) +LLSelectNode* LLObjectSelection::getFirstRootNode(LLSelectedNodeFunctor* func, BOOL non_root_ok) +{ + for (root_iterator iter = root_begin(); iter != root_end(); ++iter) { - LLViewerObject *parent; - while ((parent = (LLViewerObject*)object->getParent())) + LLSelectNode* node = *iter; + if (func == NULL || func->apply(node)) { - if (parent->isSelected()) - { - object = parent; - } - else - { - break; - } + return node; } } + if (non_root_ok) + { + // Get non root + return getFirstNode(func); + } + return NULL; +} - return object; + +//----------------------------------------------------------------------------- +// getFirstSelectedObject +//----------------------------------------------------------------------------- +LLViewerObject* LLObjectSelection::getFirstSelectedObject(LLSelectedNodeFunctor* func, BOOL get_parent) +{ + LLSelectNode* res = getFirstNode(func); + if (res && get_parent) + { + return getSelectedParentObject(res->getObject()); + } + else if (res) + { + return res->getObject(); + } + return NULL; } +//----------------------------------------------------------------------------- +// getFirstObject() +//----------------------------------------------------------------------------- +LLViewerObject* LLObjectSelection::getFirstObject() +{ + LLSelectNode* res = getFirstNode(NULL); + return res ? res->getObject() : NULL; +} //----------------------------------------------------------------------------- -// getFirstDeleteableObject() +// getFirstRootObject() //----------------------------------------------------------------------------- -LLViewerObject* LLObjectSelection::getFirstDeleteableObject(BOOL get_root) +LLViewerObject* LLObjectSelection::getFirstRootObject(BOOL non_root_ok) { - //RN: don't currently support deletion of child objects, as that requires separating them first - // then derezzing to trash - get_root = TRUE; + LLSelectNode* res = getFirstRootNode(NULL, non_root_ok); + return res ? res->getObject() : NULL; +} - LLViewerObject* object = NULL; - if (get_root) +//----------------------------------------------------------------------------- +// getFirstMoveableNode() +//----------------------------------------------------------------------------- +LLSelectNode* LLObjectSelection::getFirstMoveableNode(BOOL get_root_first) +{ + struct f : public LLSelectedNodeFunctor { - for(LLViewerObject* current = getFirstRootObject(); - current != NULL; - current = getNextRootObject()) + bool apply(LLSelectNode* node) { - // you can delete an object if permissions allow it, you are - // the owner, you are an officer in the group that owns the - // object, or you are not the owner but it is on land you own - // or land owned by your group. (whew!) - if( (current->permModify()) - || (current->permYouOwner()) - || (!current->permAnyOwner()) // public - || (current->isOverAgentOwnedLand()) - || (current->isOverGroupOwnedLand()) - ) - { + LLViewerObject* obj = node->getObject(); + return obj->permMove(); + } + } func; + LLSelectNode* res = get_root_first ? getFirstRootNode(&func, TRUE) : getFirstNode(&func); + return res; +} - if( !current->isAttachment() ) - { - object = current; - break; - } - } - } - } - else +//----------------------------------------------------------------------------- +// getFirstCopyableObject() +//----------------------------------------------------------------------------- +LLViewerObject* LLObjectSelection::getFirstCopyableObject(BOOL get_parent) +{ + struct f : public LLSelectedNodeFunctor + { + bool apply(LLSelectNode* node) + { + LLViewerObject* obj = node->getObject(); + return obj->permCopy() && !obj->isAttachment(); + } + } func; + return getFirstSelectedObject(&func, get_parent); +} + +//----------------------------------------------------------------------------- +// getFirstDeleteableObject() +//----------------------------------------------------------------------------- +LLViewerObject* LLObjectSelection::getFirstDeleteableObject() +{ + //RN: don't currently support deletion of child objects, as that requires separating them first + // then derezzing to trash + + struct f : public LLSelectedNodeFunctor { - // We've avoided this path for a while. It may not work. - llwarns << "!get_root code path may have bitrotted." << llendl; - for(LLViewerObject* current = getFirstObject(); - current != NULL; - current = getNextObject()) + bool apply(LLSelectNode* node) { + LLViewerObject* obj = node->getObject(); // you can delete an object if permissions allow it, you are // the owner, you are an officer in the group that owns the // object, or you are not the owner but it is on land you own // or land owned by your group. (whew!) - if( (current->permModify()) - || (current->permYouOwner()) - || (!current->permAnyOwner()) // public - || (current->isOverAgentOwnedLand()) - || (current->isOverGroupOwnedLand()) - ) + if( (obj->permModify()) + || (obj->permYouOwner()) + || (!obj->permAnyOwner()) // public + || (obj->isOverAgentOwnedLand()) + || (obj->isOverGroupOwnedLand()) + ) { - if( !current->isAttachment() ) + if( !obj->isAttachment() ) { - object = current; - break; + return TRUE; } } - } - } - - return object; + return true; + } + } func; + LLSelectNode* node = getFirstNode(&func); + return node ? node->getObject() : NULL; } - //----------------------------------------------------------------------------- // getFirstEditableObject() //----------------------------------------------------------------------------- -LLViewerObject* LLObjectSelection::getFirstEditableObject(BOOL get_root) +LLViewerObject* LLObjectSelection::getFirstEditableObject(BOOL get_parent) { - LLViewerObject* object = NULL; - for(LLViewerObject* cur = getFirstObject(); cur; cur = getNextObject()) - { - if( cur->permModify() ) - { - object = cur; - break; - } - } - - if (get_root && object) + struct f : public LLSelectedNodeFunctor { - LLViewerObject *parent; - while ((parent = (LLViewerObject*)object->getParent())) + bool apply(LLSelectNode* node) { - if (parent->isSelected()) - { - object = parent; - } - else - { - break; - } + LLViewerObject* obj = node->getObject(); + return obj->permModify(); } - } - - return object; + } func; + return getFirstSelectedObject(&func, get_parent); } //----------------------------------------------------------------------------- // getFirstMoveableObject() //----------------------------------------------------------------------------- -LLViewerObject* LLObjectSelection::getFirstMoveableObject(BOOL get_root) +LLViewerObject* LLObjectSelection::getFirstMoveableObject(BOOL get_parent) { - LLViewerObject* object = NULL; - for(LLViewerObject* cur = getFirstObject(); cur; cur = getNextObject()) - { - if( cur->permMove() ) - { - object = cur; - break; - } - } - - if (get_root && object && !object->isJointChild()) + struct f : public LLSelectedNodeFunctor { - LLViewerObject *parent; - while ((parent = (LLViewerObject*)object->getParent())) + bool apply(LLSelectNode* node) { - if (parent->isSelected()) - { - object = parent; - } - else - { - break; - } + LLViewerObject* obj = node->getObject(); + return obj->permMove(); } - } - - return object; + } func; + return getFirstSelectedObject(&func, get_parent); } diff --git a/linden/indra/newview/llselectmgr.h b/linden/indra/newview/llselectmgr.h index fec3a0a..26b919b 100644 --- a/linden/indra/newview/llselectmgr.h +++ b/linden/indra/newview/llselectmgr.h @@ -2,6 +2,8 @@ * @file llselectmgr.h * @brief A manager for selected objects and TEs. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,13 +26,13 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSELECTMGR_H #define LL_LLSELECTMGR_H #include "llcharacter.h" -#include "lldarray.h" #include "lleditmenuhandler.h" #include "llstring.h" #include "llundo.h" @@ -44,8 +46,10 @@ #include "llframetimer.h" #include "llbbox.h" #include "llpermissions.h" +#include "llviewerobject.h" #include +#include "boost/iterator/filter_iterator.hpp" class LLMessageSystem; class LLViewerImage; @@ -58,27 +62,37 @@ const S32 SELECT_ALL_TES = -1; const S32 SELECT_MAX_TES = 32; // Do something to all objects in the selection manager. -// The bool return value can be used to indicate if all +// The BOOL return value can be used to indicate if all // objects are identical (gathering information) or if // the operation was successful. -class LLSelectedObjectFunctor +struct LLSelectedObjectFunctor { -public: virtual ~LLSelectedObjectFunctor() {}; virtual bool apply(LLViewerObject* object) = 0; }; // Do something to all select nodes in the selection manager. -// The bool return value can be used to indicate if all +// The BOOL return value can be used to indicate if all // objects are identical (gathering information) or if // the operation was successful. -class LLSelectedNodeFunctor +struct LLSelectedNodeFunctor { -public: virtual ~LLSelectedNodeFunctor() {}; virtual bool apply(LLSelectNode* node) = 0; }; +struct LLSelectedTEFunctor +{ + virtual ~LLSelectedTEFunctor() {}; + virtual bool apply(LLViewerObject* object, S32 face) = 0; +}; + +template struct LLSelectedTEGetFunctor +{ + virtual ~LLSelectedTEGetFunctor() {}; + virtual T get(LLViewerObject* object, S32 te) = 0; +}; + typedef enum e_send_type { SEND_ONLY_ROOTS, @@ -111,53 +125,165 @@ typedef enum e_selection_type SELECT_TYPE_HUD }ESelectType; -class LLObjectSelection : public std::list, public LLRefCount +// Contains information about a selected object, particularly which TEs are selected. +class LLSelectNode +{ +public: + LLSelectNode(LLViewerObject* object, BOOL do_glow); + LLSelectNode(const LLSelectNode& nodep); + ~LLSelectNode(); + + void selectAllTEs(BOOL b); + void selectTE(S32 te_index, BOOL selected); + BOOL isTESelected(S32 te_index); + S32 getLastSelectedTE(); + void renderOneSilhouette(const LLColor4 &color); + void setTransient(BOOL transient) { mTransient = transient; } + BOOL isTransient() { return mTransient; } + LLViewerObject* getObject(); + void setObject(LLViewerObject* object); + // *NOTE: invalidate stored textures and colors when # faces change + void saveColors(); + void saveTextures(const std::vector& textures); + void saveTextureScaleRatios(); + + BOOL allowOperationOnNode(PermissionBit op, U64 group_proxy_power) const; + +public: + BOOL mIndividualSelection; // For root objects and objects individually selected + + BOOL mTransient; + BOOL mValid; // is extra information valid? + LLPermissions* mPermissions; + LLSaleInfo mSaleInfo; + LLAggregatePermissions mAggregatePerm; + LLAggregatePermissions mAggregateTexturePerm; + LLAggregatePermissions mAggregateTexturePermOwner; + LLString mName; + LLString mDescription; + LLCategory mCategory; + S16 mInventorySerial; + LLVector3 mSavedPositionLocal; // for interactively modifying object position + LLVector3 mLastPositionLocal; + LLVector3d mSavedPositionGlobal; // for interactively modifying object position + LLVector3 mSavedScale; // for interactively modifying object scale + LLVector3 mLastScale; + LLQuaternion mSavedRotation; // for interactively modifying object rotation + LLQuaternion mLastRotation; + BOOL mDuplicated; + LLVector3d mDuplicatePos; + LLQuaternion mDuplicateRot; + LLUUID mItemID; + LLUUID mFolderID; + LLUUID mFromTaskID; + LLString mTouchName; + LLString mSitName; + U64 mCreationDate; + std::vector mSavedColors; + std::vector mSavedTextures; + std::vector mTextureScaleRatios; + std::vector mSilhouetteVertices; // array of vertices to render silhouette of object + std::vector mSilhouetteNormals; // array of normals to render silhouette of object + std::vector mSilhouetteSegments; // array of normals to render silhouette of object + BOOL mSilhouetteExists; // need to generate silhouette? + +protected: + LLPointer mObject; + BOOL mTESelected[SELECT_MAX_TES]; + S32 mLastTESelected; +}; + +class LLObjectSelection : public LLRefCount { friend class LLSelectMgr; protected: ~LLObjectSelection(); + // List +public: + typedef std::list list_t; +private: + list_t mList; + +public: + // Iterators + struct is_non_null + { + bool operator()(LLSelectNode* node) + { + return (node->getObject() != NULL); + } + }; + typedef boost::filter_iterator iterator; + iterator begin() { return iterator(mList.begin(), mList.end()); } + iterator end() { return iterator(mList.end(), mList.end()); } + + struct is_valid + { + bool operator()(LLSelectNode* node) + { + return (node->getObject() != NULL) && node->mValid; + } + }; + typedef boost::filter_iterator valid_iterator; + valid_iterator valid_begin() { return valid_iterator(mList.begin(), mList.end()); } + valid_iterator valid_end() { return valid_iterator(mList.end(), mList.end()); } + + struct is_root + { + bool operator()(LLSelectNode* node) + { + LLViewerObject* object = node->getObject(); + return (object != NULL) && !node->mIndividualSelection && (object->isRootEdit() || object->isJointChild()); + } + }; + typedef boost::filter_iterator root_iterator; + root_iterator root_begin() { return root_iterator(mList.begin(), mList.end()); } + root_iterator root_end() { return root_iterator(mList.end(), mList.end()); } + + struct is_valid_root + { + bool operator()(LLSelectNode* node) + { + LLViewerObject* object = node->getObject(); + return (object != NULL) && node->mValid && !node->mIndividualSelection && (object->isRootEdit() || object->isJointChild()); + } + }; + typedef boost::filter_iterator valid_root_iterator; + valid_root_iterator valid_root_begin() { return valid_root_iterator(mList.begin(), mList.end()); } + valid_root_iterator valid_root_end() { return valid_root_iterator(mList.end(), mList.end()); } + public: LLObjectSelection(); void updateEffects(); + void cleanupNodes(); BOOL isEmpty(); S32 getOwnershipCost(S32 &cost); - LLSelectNode* getFirstNode(); - LLSelectNode* getCurrentNode(); // Warning! This is NOT the same as the linked_list getCurrentNode - LLSelectNode* getNextNode(); - - LLSelectNode *getFirstRootNode(); - LLSelectNode *getNextRootNode(); - - LLSelectNode* getFirstMoveableNode(BOOL get_root = FALSE); - - // iterate through objects - LLViewerObject* getFirstObject(); - LLViewerObject* getNextObject(); - - // iterate through root objects - LLViewerObject *getFirstRootObject(); - LLViewerObject *getNextRootObject(); + LLSelectNode* getFirstNode(LLSelectedNodeFunctor* func = NULL); + LLSelectNode* getFirstRootNode(LLSelectedNodeFunctor* func = NULL, BOOL non_root_ok = FALSE); + LLViewerObject* getFirstSelectedObject(LLSelectedNodeFunctor* func, BOOL get_parent = FALSE); + LLViewerObject* getFirstObject(); + LLViewerObject* getFirstRootObject(BOOL non_root_ok = FALSE); + + LLSelectNode* getFirstMoveableNode(BOOL get_root_first = FALSE); - LLViewerObject* getFirstEditableObject(BOOL get_root = FALSE); - LLViewerObject* getFirstCopyableObject(BOOL get_root = FALSE); - LLViewerObject* getFirstDeleteableObject(BOOL get_root = FALSE); - LLViewerObject* getFirstMoveableObject(BOOL get_root = FALSE); + LLViewerObject* getFirstEditableObject(BOOL get_parent = FALSE); + LLViewerObject* getFirstCopyableObject(BOOL get_parent = FALSE); + LLViewerObject* getFirstDeleteableObject(); + LLViewerObject* getFirstMoveableObject(BOOL get_parent = FALSE); LLViewerObject* getPrimaryObject() { return mPrimaryObject; } // iterate through texture entries - void getPrimaryTE(LLViewerObject* *object, S32 *te); - void getFirstTE(LLViewerObject* *object, S32 *te); - void getNextTE(LLViewerObject* *object, S32 *te); - void getCurrentTE(LLViewerObject* *object, S32 *te); - + template bool getSelectedTEValue(LLSelectedTEGetFunctor* func, T& res); + void addNode(LLSelectNode *nodep); void addNodeAtEnd(LLSelectNode *nodep); + void moveNodeToFront(LLSelectNode *nodep); void removeNode(LLSelectNode *nodep); void deleteAllNodes(); // Delete all nodes S32 getNumNodes(); @@ -175,21 +301,22 @@ public: BOOL isAttachment(); // Apply functors to various subsets of the selected objects - // Returns the AND of all apply() calls. - bool applyToRootObjects(LLSelectedObjectFunctor* func); - bool applyToObjects(LLSelectedObjectFunctor* func); - bool applyToNodes(LLSelectedNodeFunctor* func); + // If firstonly is FALSE, returns the AND of all apply() calls. + // Else returns TRUE immediately if any apply() call succeeds (i.e. OR with early exit) + bool applyToRootObjects(LLSelectedObjectFunctor* func, bool firstonly = false); + bool applyToObjects(LLSelectedObjectFunctor* func, bool firstonly = false); + bool applyToTEs(LLSelectedTEFunctor* func, bool firstonly = false); + bool applyToRootNodes(LLSelectedNodeFunctor* func, bool firstonly = false); + bool applyToNodes(LLSelectedNodeFunctor* func, bool firstonly = false); ESelectType getSelectType() { return mSelectType; } private: const LLObjectSelection &operator=(const LLObjectSelection &); - LLPointer mPrimaryObject; - std::list::iterator mCurrentNode; - S32 mCurrentTE; - std::map, LLSelectNode*> mSelectNodeMap; - ESelectType mSelectType; + LLPointer mPrimaryObject; + std::map, LLSelectNode*> mSelectNodeMap; + ESelectType mSelectType; }; typedef LLHandle LLObjectSelectionHandle; @@ -236,6 +363,8 @@ public: virtual void duplicate(); virtual BOOL canDuplicate(); + void clearSelections(); + void update(); void updateEffects(); // Update HUD effects void overrideObjectUpdates(); @@ -258,7 +387,7 @@ public: LLObjectSelectionHandle selectObjectAndFamily(LLViewerObject* object, BOOL add_to_end = FALSE); // Same as above, but takes a list of objects. Used by rectangle select. - LLObjectSelectionHandle selectObjectAndFamily(const LLDynamicArray& object_list, BOOL send_to_sim = TRUE); + LLObjectSelectionHandle selectObjectAndFamily(const std::vector& object_list, BOOL send_to_sim = TRUE); // converts all objects currently highlighted to a selection, and returns it LLObjectSelectionHandle selectHighlightedObjects(); @@ -267,7 +396,7 @@ public: void highlightObjectOnly(LLViewerObject *objectp); void highlightObjectAndFamily(LLViewerObject *objectp); - void highlightObjectAndFamily(const LLDynamicArray& list); + void highlightObjectAndFamily(const std::vector& list); //////////////////////////////////////////////////////////////// // Remove @@ -314,7 +443,7 @@ public: EGridMode getGridMode() { return mGridMode; } void getGrid(LLVector3& origin, LLQuaternion& rotation, LLVector3 &scale); - BOOL getTEMode() { return mTEMode; } + BOOL getTEMode() { return mTEMode; } void setTEMode(BOOL b) { mTEMode = b; } BOOL shouldShowSelection() { return mShowSelection; } @@ -343,17 +472,8 @@ public: void selectionDump(); BOOL selectionAllPCode(LLPCode code); // all objects have this PCode - BOOL selectionGetMaterial(U8 *material); // all objects have same material - BOOL selectionGetTexUUID(LLUUID& id); // true if all selected tes have same texture - BOOL selectionGetColor(LLColor4 &color); // all tes have same color - BOOL selectionGetTexScale(F32 *u, F32 *v); // true if all selected tes have same scale - BOOL selectionGetTexOffset(F32 *u, F32 *v); // true if all selected tes have same offset - BOOL selectionGetTexRotation(F32 *rad); // true if all selected tes have same rotation - BOOL selectionGetBumpmap(U8 *bumpmap); // true if all selected tes have same - BOOL selectionGetShiny(U8 *shiny); // true if all selected tes have same - BOOL selectionGetFullbright(U8 *fullbright);// true if all selected tes have same - bool selectionGetMediaType(U8 *media_type); // true if all selected tes have same - BOOL selectionGetClickAction(U8* action); + BOOL selectionGetClickAction(U8 *out_action); + bool selectionGetIncludeInSearch(bool* include_in_search_out); // true if all selected objects have same void selectionSetMaterial(U8 material); void selectionSetImage(const LLUUID& imageid); // could be item or asset id @@ -368,6 +488,7 @@ public: void selectionSetFullbright( U8 fullbright ); void selectionSetMediaTypeAndURL( U8 media_type, const std::string& media_url ); void selectionSetClickAction(U8 action); + void selectionSetIncludeInSearch(bool include_in_search); void selectionSetObjectPermissions(U8 perm_field, BOOL set, U32 perm_mask, BOOL override = FALSE); void selectionSetObjectName(const LLString& name); @@ -376,9 +497,7 @@ public: void selectionSetObjectSaleInfo(const LLSaleInfo& sale_info); void selectionTexScaleAutofit(F32 repeats_per_meter); - void selectionResetTexInfo(S32 te); // sets S,T to 1 void adjustTexturesByScale(BOOL send_to_sim, BOOL stretch); - BOOL getTESTAxes(const LLViewerObject* object, const U8 te, U32* s_axis, U32* t_axis); // Only for flex boxes void selectionResetRotation(); // sets rotation quat to identity void selectionRotateAroundZ(F32 degrees); @@ -391,7 +510,7 @@ public: // returns TRUE if it is possible to select this object BOOL canSelectObject(LLViewerObject* object); - // Returns true if the viewer has information on all selected objects + // Returns TRUE if the viewer has information on all selected objects BOOL selectGetAllRootsValid(); BOOL selectGetAllValid(); @@ -405,17 +524,17 @@ public: // returns TRUE if selected objects can be copied. BOOL selectGetRootsCopy(); - BOOL selectGetCreator(LLUUID& id, LLString& name); // true if all have same creator, returns id - BOOL selectGetOwner(LLUUID& id, LLString& name); // true if all objects have same owner, returns id - BOOL selectGetLastOwner(LLUUID& id, LLString& name); // true if all objects have same owner, returns id + BOOL selectGetCreator(LLUUID& id, LLString& name); // TRUE if all have same creator, returns id + BOOL selectGetOwner(LLUUID& id, LLString& name); // TRUE if all objects have same owner, returns id + BOOL selectGetLastOwner(LLUUID& id, LLString& name); // TRUE if all objects have same owner, returns id // returns TRUE if all are the same. id is stuffed with // the value found if available. BOOL selectGetGroup(LLUUID& id); - BOOL selectGetPerm( U8 which_perm, U32* mask_on, U32* mask_off); // true if all have data, returns two masks, each indicating which bits are all on and all off + BOOL selectGetPerm( U8 which_perm, U32* mask_on, U32* mask_off); // TRUE if all have data, returns two masks, each indicating which bits are all on and all off BOOL selectGetOwnershipCost(S32* cost); // sum of all ownership costs - BOOL selectIsGroupOwned(); // true if all root objects have valid data and are group owned. + BOOL selectIsGroupOwned(); // TRUE if all root objects have valid data and are group owned. // returns TRUE if all the nodes are valid. Accumulates // permissions in the parameter. @@ -483,10 +602,15 @@ public: LLVector3d getSelectionCenterGlobal() const { return mSelectionCenterGlobal; } void updateSelectionCenter(); - void updatePointAt(); + + void resetAgentHUDZoom(); + void setAgentHUDZoom(F32 target_zoom, F32 current_zoom); + void getAgentHUDZoom(F32 &target_zoom, F32 ¤t_zoom) const; + + void updatePointAt(); // Internal list maintenance functions. TODO: Make these private! - void remove(LLDynamicArray& objects); + void remove(std::vector& objects); void remove(LLViewerObject* object, S32 te = SELECT_ALL_TES, BOOL undoable = TRUE); void removeAll(); void addAsIndividual(LLViewerObject* object, S32 te = SELECT_ALL_TES, BOOL undoable = TRUE); @@ -496,7 +620,7 @@ public: private: void convertTransient(); // converts temporarily selected objects to full-fledged selections ESelectType getSelectTypeForObject(LLViewerObject* object); - void addAsFamily(LLDynamicArray& objects, BOOL add_to_end = FALSE); + void addAsFamily(std::vector& objects, BOOL add_to_end = FALSE); void generateSilhouette(LLSelectNode *nodep, const LLVector3& view_point); // Send one message to each region containing an object on selection list. void sendListToRegions( const LLString& message_name, @@ -518,6 +642,7 @@ private: static void packObjectIDAndRotation( LLSelectNode* node, void *); static void packObjectLocalID(LLSelectNode* node, void *); static void packObjectClickAction(LLSelectNode* node, void* data); + static void packObjectIncludeInSearch(LLSelectNode* node, void* data); static void packObjectName(LLSelectNode* node, void* user_data); static void packObjectDescription(LLSelectNode* node, void* user_data); static void packObjectCategory(LLSelectNode* node, void* user_data); @@ -568,78 +693,71 @@ private: LLAnimPauseRequest mPauseRequest; }; - -// Contains information about a selected object, particularly which -// tes are selected. -class LLSelectNode -{ -public: - LLSelectNode(LLViewerObject* object, BOOL do_glow); - LLSelectNode(const LLSelectNode& nodep); - ~LLSelectNode(); - - void selectAllTEs(BOOL b); - void selectTE(S32 te_index, BOOL selected); - BOOL isTESelected(S32 te_index); - S32 getLastSelectedTE(); - void renderOneSilhouette(const LLColor4 &color); - void setTransient(BOOL transient) { mTransient = transient; } - BOOL isTransient() { return mTransient; } - LLViewerObject *getObject(); - // *NOTE: invalidate stored textures and colors when # faces change - void saveColors(); - void saveTextures(const std::vector& textures); - void saveTextureScaleRatios(); - - BOOL allowOperationOnNode(PermissionBit op, U64 group_proxy_power) const; - -public: - BOOL mIndividualSelection; // For root objects and objects individually selected - - BOOL mTransient; - BOOL mValid; // is extra information valid? - LLPermissions* mPermissions; - LLSaleInfo mSaleInfo; - LLAggregatePermissions mAggregatePerm; - LLAggregatePermissions mAggregateTexturePerm; - LLAggregatePermissions mAggregateTexturePermOwner; - LLString mName; - LLString mDescription; - LLCategory mCategory; - S16 mInventorySerial; - LLVector3 mSavedPositionLocal; // for interactively modifying object position - LLVector3 mLastPositionLocal; - LLVector3d mSavedPositionGlobal; // for interactively modifying object position - LLVector3 mSavedScale; // for interactively modifying object scale - LLVector3 mLastScale; - LLQuaternion mSavedRotation; // for interactively modifying object rotation - LLQuaternion mLastRotation; - BOOL mDuplicated; - LLVector3d mDuplicatePos; - LLQuaternion mDuplicateRot; - LLUUID mItemID; - LLUUID mFolderID; - LLUUID mFromTaskID; - LLString mTouchName; - LLString mSitName; - U64 mCreationDate; - std::vector mSavedColors; - std::vector mSavedTextures; - std::vector mTextureScaleRatios; - std::vector mSilhouetteVertices; // array of vertices to render silhouette of object - std::vector mSilhouetteNormals; // array of normals to render silhouette of object - std::vector mSilhouetteSegments; // array of normals to render silhouette of object - BOOL mSilhouetteExists; // need to generate silhouette? - -protected: - LLPointer mObject; - BOOL mTESelected[SELECT_MAX_TES]; - S32 mLastTESelected; -}; - extern LLSelectMgr* gSelectMgr; // Utilities void dialog_refresh_all(); // Update subscribers to the selection list +// Templates +//----------------------------------------------------------------------------- +// getSelectedTEValue +//----------------------------------------------------------------------------- +template bool LLObjectSelection::getSelectedTEValue(LLSelectedTEGetFunctor* func, T& res) +{ + bool have_first = false; + bool have_selected = false; + T selected_value = T(); + + // Now iterate through all TEs to test for sameness + bool identical = TRUE; + for (iterator iter = begin(); iter != end(); iter++) + { + LLSelectNode* node = *iter; + LLViewerObject* object = node->getObject(); + S32 selected_te = -1; + if (object == getPrimaryObject()) + { + selected_te = node->getLastSelectedTE(); + } + for (S32 te = 0; te < object->getNumTEs(); ++te) + { + if (!node->isTESelected(te)) + { + continue; + } + T value = func->get(object, te); + if (!have_first) + { + have_first = true; + if (!have_selected) + { + selected_value = value; + } + } + else + { + if ( value != selected_value ) + { + identical = false; + } + if (te == selected_te) + { + selected_value = value; + have_selected = true; + } + } + } + if (!identical && have_selected) + { + break; + } + } + if (have_first || have_selected) + { + res = selected_value; + } + return identical; +} + + #endif diff --git a/linden/indra/newview/llsky.cpp b/linden/indra/newview/llsky.cpp index 40cc532..eadac8a 100644 --- a/linden/indra/newview/llsky.cpp +++ b/linden/indra/newview/llsky.cpp @@ -2,6 +2,8 @@ * @file llsky.cpp * @brief IndraWorld sky class * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Ideas: diff --git a/linden/indra/newview/llsky.h b/linden/indra/newview/llsky.h index f6acb1d..690b54a 100644 --- a/linden/indra/newview/llsky.h +++ b/linden/indra/newview/llsky.h @@ -2,6 +2,8 @@ * @file llsky.h * @brief It's, uh, the sky! * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSKY_H diff --git a/linden/indra/newview/llspatialpartition.cpp b/linden/indra/newview/llspatialpartition.cpp index 00bb724..6cd1ace 100644 --- a/linden/indra/newview/llspatialpartition.cpp +++ b/linden/indra/newview/llspatialpartition.cpp @@ -2,6 +2,8 @@ * @file llspatialpartition.cpp * @brief LLSpatialGroup class implementation and supporting functions * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llspatialpartition.h b/linden/indra/newview/llspatialpartition.h index 31ec040..5376493 100644 --- a/linden/indra/newview/llspatialpartition.h +++ b/linden/indra/newview/llspatialpartition.h @@ -2,6 +2,8 @@ * @file llspatialpartition.h * @brief LLSpatialGroup header file including definitions for supporting functions * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSPATIALPARTITION_H diff --git a/linden/indra/newview/llsphere.cpp b/linden/indra/newview/llsphere.cpp index 3457e0e..dedc8f2 100644 --- a/linden/indra/newview/llsphere.cpp +++ b/linden/indra/newview/llsphere.cpp @@ -2,6 +2,8 @@ * @file llsphere.cpp * @brief implementation of the LLSphere class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Sphere creates a set of display lists that can then be called to create diff --git a/linden/indra/newview/llsphere.h b/linden/indra/newview/llsphere.h index 29b42ab..17e927e 100644 --- a/linden/indra/newview/llsphere.h +++ b/linden/indra/newview/llsphere.h @@ -2,6 +2,8 @@ * @file llsphere.h * @brief interface for the LLSphere class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSPHERE_H diff --git a/linden/indra/newview/llsprite.cpp b/linden/indra/newview/llsprite.cpp index 28ace97..332a5aa 100644 --- a/linden/indra/newview/llsprite.cpp +++ b/linden/indra/newview/llsprite.cpp @@ -2,6 +2,8 @@ * @file llsprite.cpp * @brief LLSprite class implementation * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /* -*- c++ -*- diff --git a/linden/indra/newview/llsprite.h b/linden/indra/newview/llsprite.h index 7ccef73..04d30b8 100644 --- a/linden/indra/newview/llsprite.h +++ b/linden/indra/newview/llsprite.h @@ -2,6 +2,8 @@ * @file llsprite.h * @brief LLSprite class definition * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSPRITE_H diff --git a/linden/indra/newview/llsrv.cpp b/linden/indra/newview/llsrv.cpp index 5a623bc..150fcb1 100644 --- a/linden/indra/newview/llsrv.cpp +++ b/linden/indra/newview/llsrv.cpp @@ -2,7 +2,9 @@ * @file llsrv.cpp * @brief Wrapper for DNS SRV record lookups * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,352 +26,31 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" #include "llsrv.h" +#include "llares.h" -using namespace std; - -#if LL_WINDOWS - -#undef UNICODE -#include -#include - -vector LLSRV::query(const string& name) -{ - vector recs; - DNS_RECORD *rec; - DNS_STATUS status; - - status = DnsQuery(name.c_str(), DNS_TYPE_SRV, DNS_QUERY_STANDARD, NULL, &rec, NULL); - if (!status) - { - for (DNS_RECORD *cur = rec; cur != NULL; cur = cur->pNext) - { - if (cur->wType != DNS_TYPE_SRV) - { - continue; - } - recs.push_back(LLSRVRecord(cur->Data.Srv.wPriority, - cur->Data.Srv.wWeight, - cur->Data.Srv.pNameTarget, - cur->Data.Srv.wPort)); - } - DnsRecordListFree(rec, DnsFreeRecordListDeep); - } - - return recs; -} - -#else // !LL_WINDOWS - -#include -#include -#include -#include - -#include - -#ifdef HOMEGROWN_RESPONSE_PARSER - -// We ought to be using libresolv's ns_initparse and ns_parserr to -// parse the result of our query. However, libresolv isn't packaged -// correctly on Linux (as of BIND 9), so neither of these functions is -// available without statically linking against libresolv. Ugh! This -// fallback function is available if we need to parse the response -// ourselves without relying too much on libresolv. It is NOT THE -// DEFAULT. - -vector LLSRV::parseResponse(const unsigned char *response, - int resp_len) -{ - vector recs; - - const unsigned char *pos = response + sizeof(HEADER); - const unsigned char *end = response + resp_len; - const HEADER *hdr = (const HEADER *) response; - char name[1024]; - - // Skip over the query embedded in the response. - - for (int q = ntohs(hdr->qdcount); q > 0; --q) - { - int len = dn_expand(response, end, pos, name, sizeof(name)); - - if (len == -1) - { - llinfos << "Could not expand queried name in RR response" - << llendl; - goto bail; - } - - pos += len + NS_QFIXEDSZ; - } - - for (int a = ntohs(hdr->ancount); a > 0; --a) - { - static const ns_rr *rr; - - int len = dn_expand(response, end, pos, name, sizeof(name) - 1); - if (len == -1) - { - llinfos << "Could not expand response name in RR response" - << llendl; - goto bail; - } - - // Skip over the resource name and headers we don't care about. - - pos += len + sizeof(rr->type) + sizeof(rr->rr_class) + - sizeof(rr->ttl) + sizeof(rr->rdlength); - - U16 prio; - U16 weight; - U16 port; - - NS_GET16(prio, pos); - NS_GET16(weight, pos); - NS_GET16(port, pos); - - len = dn_expand(response, end, pos, name, sizeof(name) - 1); - - if (len == -1) - { - llinfos << "Could not expand name in RR response" << llendl; - goto bail; - } - - recs.push_back(LLSRVRecord(prio, weight, name, port)); - } - - // There are likely to be more records in the response, but we - // don't care about those, at least for now. -bail: - return reorder(recs); -} - -#else // HOMEGROWN_RESPONSE_PARSER - -// This version of the response parser is the one to use if libresolv -// is available and behaving itself. - -vector LLSRV::parseResponse(const unsigned char *response, - int resp_len) -{ - vector recs; - ns_msg hdr; - - if (ns_initparse(response, resp_len, &hdr)) - { - llinfos << "Could not parse response" << llendl; - goto bail; - } - - for (int i = 0; i < ns_msg_count(hdr, ns_s_an); i++) - { - ns_rr rr; - - if (ns_parserr(&hdr, ns_s_an, i, &rr)) - { - llinfos << "Could not parse RR" << llendl; - goto bail; - } - - if (ns_rr_type(rr) != ns_t_srv) - { - continue; - } - - const unsigned char *pos = ns_rr_rdata(rr); - U16 prio, weight, port; - char name[1024]; - int ret; - - NS_GET16(prio, pos); - NS_GET16(weight, pos); - NS_GET16(port, pos); - - ret = dn_expand(ns_msg_base(hdr), ns_msg_end(hdr), pos, - name, sizeof(name)); - - if (ret == -1) - { - llinfos << "Could not decompress name" << llendl; - goto bail; - } - - recs.push_back(LLSRVRecord(prio, weight, name, port)); - } - -bail: - return reorder(recs); -} - -#endif // HOMEGROWN_RESPONSE_PARSER - -vector LLSRV::query(const string& queryName) -{ - unsigned char response[16384]; - vector recs; - int len; - - len = res_query(queryName.c_str(), ns_c_in, ns_t_srv, response, - sizeof(response)); - - if (len == -1) - { - llinfos << "Query failed for " << queryName << llendl; - goto bail; - } - else if (len > (int) sizeof(response)) - { - llinfos << "Response too big for " << queryName - << " (capacity " << sizeof(response) - << ", response " << len << ")" << llendl; - goto bail; - } - - recs = parseResponse(response, len); -bail: - return reorder(recs); -} - -#endif // LL_WINDOWS - -// Implement the algorithm specified in RFC 2782 for dealing with RRs -// of differing priorities and weights. -vector LLSRV::reorder(vector& recs) +struct Responder : public LLAres::UriRewriteResponder { - typedef list reclist_t; - typedef map bucket_t; - vector newRecs; - bucket_t buckets; - - // Don't rely on the DNS server to shuffle responses. - - random_shuffle(recs.begin(), recs.end()); - - for (vector::const_iterator iter = recs.begin(); - iter != recs.end(); ++iter) - { - buckets[iter->priority()].push_back(&*iter); - } - - // Priorities take precedence over weights. - - for (bucket_t::iterator iter = buckets.begin(); - iter != buckets.end(); ++iter) - { - reclist_t& myPrio = iter->second; - reclist_t r; - - // RRs with weight zero go to the front of the intermediate - // list, so they'll have little chance of being chosen. - // Larger weights have a higher likelihood of selection. - - for (reclist_t::iterator i = myPrio.begin(); i != myPrio.end(); ) - { - if ((*i)->weight() == 0) - { - r.push_back(*i); - i = myPrio.erase(i); - } else { - ++i; - } - } - - r.insert(r.end(), myPrio.begin(), myPrio.end()); - - while (!r.empty()) + std::vector mUris; + void rewriteResult(const std::vector &uris) { + for (size_t i = 0; i < uris.size(); i++) { - U32 total = 0; - - for (reclist_t::const_iterator i = r.begin(); i != r.end(); ++i) - { - total += (*i)->weight(); - } - - U32 target = total > 1 ? (rand() % total) : 0; - U32 partial = 0; - - for (reclist_t::iterator i = r.begin(); i != r.end(); ) - { - partial += (*i)->weight(); - if (partial >= target) - { - newRecs.push_back(**i); - i = r.erase(i); - } else { - ++i; - } - } + llinfos << "[" << i << "] " << uris[i] << llendl; } + mUris = uris; } - - // Order RRs by lowest numeric priority. The stable sort - // preserves the weight choices we made above. +}; - stable_sort(newRecs.begin(), newRecs.end(), - LLSRVRecord::ComparePriorityLowest()); - - return newRecs; -} - -vector LLSRV::rewriteURI(const string& uriStr) +std::vector LLSRV::rewriteURI(const std::string& uri) { - LLURI uri(uriStr); - const string& scheme = uri.scheme(); - llinfos << "Rewriting " << uriStr << llendl; - string serviceName("_" + scheme + "._tcp." + uri.hostName()); - llinfos << "Querying for " << serviceName << llendl; - vector srvs(LLSRV::query(serviceName)); - vector rewritten; - - if (srvs.empty()) - { - llinfos << "No query results; using " << uriStr << llendl; - rewritten.push_back(uriStr); - } - else - { - vector::const_iterator iter; - size_t maxSrvs = 3; - size_t i; - - llinfos << "Got " << srvs.size() << " results" << llendl; - for (iter = srvs.begin(); iter != srvs.end(); ++iter) - { - lldebugs << "host " << iter->target() << ':' << iter->port() - << " prio " << iter->priority() - << " weight " << iter->weight() - << llendl; - } - - if (srvs.size() > maxSrvs) - { - llinfos << "Clamping to " << maxSrvs << llendl; - } - - for (iter = srvs.begin(), i = 0; - iter != srvs.end() && i < maxSrvs; ++iter, ++i) - { - LLURI newUri(scheme, - uri.userName(), - uri.password(), - iter->target(), - uri.defaultPort() ? iter->port() : uri.hostPort(), - uri.escapedPath(), - uri.escapedQuery()); - string newUriStr(newUri.asString()); - - llinfos << "Rewrite[" << i << "] " << newUriStr << llendl; - - rewritten.push_back(newUriStr); - } - } + LLPointer resp = new Responder; - return rewritten; + gAres->rewriteURI(uri, resp); + gAres->processAll(); + return resp->mUris; } diff --git a/linden/indra/newview/llsrv.h b/linden/indra/newview/llsrv.h index 9417664..28bc36a 100644 --- a/linden/indra/newview/llsrv.h +++ b/linden/indra/newview/llsrv.h @@ -2,7 +2,9 @@ * @file llsrv.h * @brief Wrapper for DNS SRV record lookups * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -24,57 +26,15 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSRV_H #define LL_LLSRV_H -class LLSRV; - -class LLSRVRecord -{ - friend class LLSRV; - -protected: - U16 mPriority; - U16 mWeight; - std::string mTarget; - U16 mPort; - -public: - LLSRVRecord(U16 priority, U16 weight, const std::string& target, - U16 port) : - mPriority(priority), - mWeight(weight), - mTarget(target), - mPort(port) { - } - - U16 priority() const { return mPriority; } - U16 weight() const { return mWeight; } - const std::string& target() const { return mTarget; } - U16 port() const { return mPort; } - - struct ComparePriorityLowest - { - bool operator()(const LLSRVRecord& lhs, const LLSRVRecord& rhs) - { - return lhs.mPriority < rhs.mPriority; - } - }; -}; - class LLSRV { -protected: -#ifndef LL_WINDOWS - static std::vector parseResponse(const unsigned char *response, - int resp_len); -#endif - static std::vector reorder(std::vector& recs); - public: - static std::vector query(const std::string& name); static std::vector rewriteURI(const std::string& uri); }; diff --git a/linden/indra/newview/llstartup.cpp b/linden/indra/newview/llstartup.cpp index 2623b05..a84590f 100644 --- a/linden/indra/newview/llstartup.cpp +++ b/linden/indra/newview/llstartup.cpp @@ -2,6 +2,8 @@ * @file llstartup.cpp * @brief startup routines. * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -43,6 +46,7 @@ #endif #include "audiosettings.h" +#include "llares.h" #include "llcachename.h" #include "llviewercontrol.h" #include "lldir.h" @@ -73,7 +77,6 @@ #include "llagent.h" #include "llagentpilot.h" -#include "llasynchostbyname.h" #include "llfloateravatarpicker.h" #include "llcallbacklist.h" #include "llcallingcard.h" @@ -127,6 +130,8 @@ #include "lltexturefetch.h" #include "lltoolmgr.h" #include "llui.h" +#include "llurldispatcher.h" +#include "llurlsimstring.h" #include "llurlwhitelist.h" #include "lluserauth.h" #include "llviewerassetstorage.h" @@ -289,6 +294,9 @@ void update_texture_fetch() gImageList.updateImages(0.10f); } +static std::vector sAuthUris; +static int sAuthUriNum = -1; + // Returns FALSE to skip other idle processing. Should only return // TRUE when all initialization done. BOOL idle_startup() @@ -307,8 +315,6 @@ BOOL idle_startup() // auth/transform loop will do. static F32 progress = 0.10f; - static std::vector auth_uris; - static int auth_uri_num = -1; static std::string auth_method; static std::string auth_desc; static std::string auth_message; @@ -403,7 +409,7 @@ BOOL idle_startup() } if (!xml_ok) { - // XUI:translate (maybe - very unlikely error message) + // *TODO:translate (maybe - very unlikely error message) // Note: alerts.xml may be invalid - if this gets translated it will need to be in the code LLString bad_xui_msg = "An error occured while updating Second Life. Please download the latest version from www.secondlife.com."; app_early_exit(bad_xui_msg); @@ -422,6 +428,11 @@ BOOL idle_startup() // Load the throttle settings gViewerThrottle.load(); + if (ll_init_ares() == NULL) + { + llerrs << "Could not start address resolution system" << llendl; + } + // // Initialize messaging system // @@ -526,7 +537,7 @@ BOOL idle_startup() // LibXUL (Mozilla) initialization //--------------------------------------------------------------------- #if LL_LIBXUL_ENABLED - set_startup_status(0.48f, "Initializing embedded web browser...", gAgent.mMOTD.c_str()); + set_startup_status(0.58f, "Initializing embedded web browser...", gAgent.mMOTD.c_str()); display_startup(); llinfos << "Initializing embedded web browser..." << llendl; @@ -781,7 +792,7 @@ BOOL idle_startup() if ( user_picked_server ) { // User picked a grid from the popup, so clear the stored urls and they will be re-generated from gUserServerChoice - auth_uris.clear(); + sAuthUris.clear(); resetURIs(); } @@ -793,7 +804,7 @@ BOOL idle_startup() //For HTML parsing in text boxes. LLTextEditor::setLinkColor( gSavedSettings.getColor4("HTMLLinkColor") ); - LLTextEditor::setURLCallbacks ( &LLWeb::loadURL, &process_secondlife_url ); + LLTextEditor::setURLCallbacks ( &LLWeb::loadURL, &LLURLDispatcher::dispatch, &LLURLDispatcher::dispatch ); //------------------------------------------------- // Handle startup progress screen @@ -895,11 +906,11 @@ BOOL idle_startup() gSavedSettings.setBOOL("UseDebugMenus", TRUE); requested_options.push_back("god-connect"); } - if (auth_uris.empty()) + if (sAuthUris.empty()) { - auth_uris = getLoginURIs(); + sAuthUris = getLoginURIs(); } - auth_uri_num = 0; + sAuthUriNum = 0; auth_method = "login_to_simulator"; auth_desc = "Logging in. "; auth_desc += gSecondLife; @@ -942,7 +953,7 @@ BOOL idle_startup() hashed_mac.hex_digest(hashed_mac_string); gUserAuthp->authenticate( - auth_uris[auth_uri_num].c_str(), + sAuthUris[sAuthUriNum].c_str(), auth_method.c_str(), firstname.c_str(), lastname.c_str(), @@ -1038,8 +1049,8 @@ BOOL idle_startup() else if(login_response && (0 == strcmp(login_response, "indeterminate"))) { llinfos << "Indeterminate login..." << llendl; - auth_uris = LLSRV::rewriteURI(gUserAuthp->getResponse("next_url")); - auth_uri_num = 0; + sAuthUris = LLSRV::rewriteURI(gUserAuthp->getResponse("next_url")); + sAuthUriNum = 0; auth_method = gUserAuthp->getResponse("next_method"); auth_message = gUserAuthp->getResponse("message"); if(auth_method.substr(0, 5) == "login") @@ -1067,7 +1078,17 @@ BOOL idle_startup() } else if (message_response) { - emsg << message_response; + // XUI: fix translation for strings returned during login + // We need a generic table for translations + LLString big_reason = LLAgent::sTeleportErrorMessages[ message_response ]; + if ( big_reason.size() == 0 ) + { + emsg << message_response; + } + else + { + emsg << big_reason; + } } if(reason_response && (0 == strcmp(reason_response, "tos"))) @@ -1144,18 +1165,18 @@ BOOL idle_startup() case LLUserAuth::E_SSL_CACERT: case LLUserAuth::E_SSL_CONNECT_ERROR: default: - if (auth_uri_num >= (int) auth_uris.size() - 1) + if (sAuthUriNum >= (int) sAuthUris.size() - 1) { emsg << "Unable to connect to " << gSecondLife << ".\n"; emsg << gUserAuthp->errorMessage(); } else { - auth_uri_num++; + sAuthUriNum++; std::ostringstream s; s << "Previous login attempt failed. Logging in, attempt " - << (auth_uri_num + 1) << ". "; + << (sAuthUriNum + 1) << ". "; auth_desc = s.str(); LLStartUp::setStartupState( STATE_LOGIN_AUTHENTICATE ); - auth_uri_num++; + sAuthUriNum++; return do_normal_idle; } break; @@ -1638,12 +1659,17 @@ BOOL idle_startup() gSky.init(initial_sun_direction); } - set_startup_status(0.45f, "Decoding UI images...", gAgent.mMOTD.c_str()); - display_startup(); llinfos << "Decoding images..." << llendl; // For all images pre-loaded into viewer cache, decode them. // Need to do this AFTER we init the sky - gImageList.decodeAllImages(2.f); + const S32 DECODE_TIME_SEC = 2; + for (int i = 0; i < DECODE_TIME_SEC; i++) + { + F32 frac = (F32)i / (F32)DECODE_TIME_SEC; + set_startup_status(0.45f + frac*0.1f, "Decoding images...", gAgent.mMOTD.c_str()); + display_startup(); + gImageList.decodeAllImages(1.f); + } LLStartUp::setStartupState( STATE_QUICKTIME_INIT ); // JC - Do this as late as possible to increase likelihood Purify @@ -1693,7 +1719,7 @@ BOOL idle_startup() { // initialize quicktime libraries (fails gracefully if quicktime not installed ($QUICKTIME) llinfos << "Initializing QuickTime...." << llendl; - set_startup_status(0.47f, "Initializing QuickTime...", gAgent.mMOTD.c_str()); + set_startup_status(0.57f, "Initializing QuickTime...", gAgent.mMOTD.c_str()); display_startup(); #if LL_WINDOWS // Only necessary/available on Windows. @@ -1702,12 +1728,12 @@ BOOL idle_startup() // quicktime init failed - turn off media engine support LLMediaEngine::getInstance ()->setAvailable ( FALSE ); llinfos << "...not found - unable to initialize." << llendl; - set_startup_status(0.47f, "QuickTime not found - unable to initialize.", gAgent.mMOTD.c_str()); + set_startup_status(0.57f, "QuickTime not found - unable to initialize.", gAgent.mMOTD.c_str()); } else { llinfos << ".. initialized successfully." << llendl; - set_startup_status(0.47f, "QuickTime initialized successfully.", gAgent.mMOTD.c_str()); + set_startup_status(0.57f, "QuickTime initialized successfully.", gAgent.mMOTD.c_str()); }; #endif EnterMovies (); @@ -1725,7 +1751,7 @@ BOOL idle_startup() if(STATE_WORLD_WAIT == LLStartUp::getStartupState()) { //llinfos << "Waiting for simulator ack...." << llendl; - set_startup_status(0.49f, "Waiting for region handshake...", gAgent.mMOTD.c_str()); + set_startup_status(0.59f, "Waiting for region handshake...", gAgent.mMOTD.c_str()); if(gGotUseCircuitCodeAck) { LLStartUp::setStartupState( STATE_AGENT_SEND ); @@ -1744,7 +1770,7 @@ BOOL idle_startup() if (STATE_AGENT_SEND == LLStartUp::getStartupState()) { llinfos << "Connecting to region..." << llendl; - set_startup_status(0.50f, "Connecting to region...", gAgent.mMOTD.c_str()); + set_startup_status(0.60f, "Connecting to region...", gAgent.mMOTD.c_str()); // register with the message system so it knows we're // expecting this message LLMessageSystem* msg = gMessageSystem; @@ -2107,6 +2133,7 @@ BOOL idle_startup() gInitializationComplete = TRUE; gRenderStartTime.reset(); + gForegroundTime.reset(); // HACK: Inform simulator of window size. // Do this here so it's less likely to race with RegisterNewAgent. @@ -2187,7 +2214,7 @@ BOOL idle_startup() else { update_texture_fetch(); - set_startup_status(0.50f + 0.50f * timeout_frac, "Precaching...", + set_startup_status(0.60f + 0.40f * timeout_frac, "Precaching...", gAgent.mMOTD.c_str()); } @@ -2268,25 +2295,8 @@ BOOL idle_startup() gAgentPilot.startPlayback(); } - // ok, if we've gotten this far and have a startup URL - if (LLURLSimString::sInstance.parse()) - { - // kick off request for landmark to startup URL - if(gFloaterWorldMap) - { - LLVector3 pos = gAgent.getPositionAgent(); - if( LLURLSimString::sInstance.mSimName != gAgent.getRegion()->getName() - || LLURLSimString::sInstance.mX != llfloor(pos[VX]) - || LLURLSimString::sInstance.mY != llfloor(pos[VY]) ) - { - LLFloaterWorldMap::show(NULL, TRUE); - gFloaterWorldMap->trackURL(LLURLSimString::sInstance.mSimName, - LLURLSimString::sInstance.mX, - LLURLSimString::sInstance.mY, - LLURLSimString::sInstance.mZ); - } - } - } + // If we've got a startup URL, dispatch it + LLStartUp::dispatchURL(); // Clean up the userauth stuff. if (gUserAuthp) @@ -2331,11 +2341,8 @@ void login_show() bUseDebugLogin, login_callback, NULL ); - llinfos << "Decoding Images" << llendl; + // UI textures have been previously loaded in doPreloadImages() - // Make sure all the UI textures are present and decoded. - gImageList.decodeAllImages(2.f); - llinfos << "Setting Servers" << llendl; if( USERSERVER_OTHER == gUserServerChoice ) @@ -2573,7 +2580,7 @@ void update_app(BOOL mandatory, const std::string& auth_msg) std::ostringstream message; - //XUI:translate + //*TODO:translate std::string msg; if (!auth_msg.empty()) { @@ -2915,11 +2922,11 @@ void register_viewer_callbacks(LLMessageSystem* msg) msg->setHandlerFuncFast(_PREHASH_GrantGodlikePowers, process_grant_godlike_powers); msg->setHandlerFuncFast(_PREHASH_GroupAccountSummaryReply, - LLGroupMoneyPlanningTabEventHandler::processGroupAccountSummaryReply); + LLPanelGroupLandMoney::processGroupAccountSummaryReply); msg->setHandlerFuncFast(_PREHASH_GroupAccountDetailsReply, - LLGroupMoneyDetailsTabEventHandler::processGroupAccountDetailsReply); + LLPanelGroupLandMoney::processGroupAccountDetailsReply); msg->setHandlerFuncFast(_PREHASH_GroupAccountTransactionsReply, - LLGroupMoneySalesTabEventHandler::processGroupAccountTransactionsReply); + LLPanelGroupLandMoney::processGroupAccountTransactionsReply); msg->setHandlerFuncFast(_PREHASH_UserInfoReply, process_user_info_reply); @@ -3102,67 +3109,6 @@ void init_stat_view() stat_barp->mDisplayBar = FALSE; - // Pipeline statistics - LLStatView *pipeline_statviewp; - pipeline_statviewp = new LLStatView("pipeline stat view", "Pipeline", "", rect); - render_statviewp->addChildAtEnd(pipeline_statviewp); - - stat_barp = pipeline_statviewp->addStat("Visible Drawables", &(gPipeline.mNumVisibleDrawablesStat)); - stat_barp->setUnitLabel(""); - stat_barp->mMinBar = 0.f; - stat_barp->mMaxBar = 10000.f; - stat_barp->mTickSpacing = 1000.f; - stat_barp->mLabelSpacing = 5000.f; - stat_barp->mPerSec = FALSE; - - stat_barp = pipeline_statviewp->addStat("Visible Faces", &(gPipeline.mNumVisibleFacesStat)); - stat_barp->setUnitLabel(""); - stat_barp->mMinBar = 0.f; - stat_barp->mMaxBar = 40000.f; - stat_barp->mTickSpacing = 5000.f; - stat_barp->mLabelSpacing = 10000.f; - stat_barp->mPerSec = FALSE; - - stat_barp = pipeline_statviewp->addStat("DirtyGeom", &(gPipeline.mGeometryChangesStat)); - stat_barp->setUnitLabel("/fr"); - stat_barp->mMinBar = 0.f; - stat_barp->mMaxBar = 1000.f; - stat_barp->mTickSpacing = 100.f; - stat_barp->mLabelSpacing = 500.f; - stat_barp->mPerSec = FALSE; - - stat_barp = pipeline_statviewp->addStat("DirtyLight", &(gPipeline.mLightingChangesStat)); - stat_barp->setUnitLabel("/fr"); - stat_barp->mMinBar = 0.f; - stat_barp->mMaxBar = 1000.f; - stat_barp->mTickSpacing = 100.f; - stat_barp->mLabelSpacing = 500.f; - stat_barp->mPerSec = FALSE; - - stat_barp = pipeline_statviewp->addStat("MoveList", &(gPipeline.mMoveChangesStat)); - stat_barp->setUnitLabel("dr"); - stat_barp->mMinBar = 0.f; - stat_barp->mMaxBar = 1000.f; - stat_barp->mTickSpacing = 100.f; - stat_barp->mLabelSpacing = 500.f; - stat_barp->mPerSec = FALSE; - - stat_barp = pipeline_statviewp->addStat("Compiles", &(gPipeline.mCompilesStat)); - stat_barp->setUnitLabel("/fr"); - stat_barp->mMinBar = 0.f; - stat_barp->mMaxBar = 1000.f; - stat_barp->mTickSpacing = 100.f; - stat_barp->mLabelSpacing = 500.f; - stat_barp->mPerSec = FALSE; - - stat_barp = pipeline_statviewp->addStat("Verts Relit", &(gPipeline.mVerticesRelitStat)); - stat_barp->setUnitLabel("/fr"); - stat_barp->mMinBar = 0.f; - stat_barp->mMaxBar = 40000.f; - stat_barp->mTickSpacing = 10000.f; - stat_barp->mLabelSpacing = 20000.f; - stat_barp->mPerSec = FALSE; - // Texture statistics LLStatView *texture_statviewp; texture_statviewp = new LLStatView("texture stat view", "Texture", "", rect); @@ -3604,7 +3550,6 @@ void callback_choose_gender(S32 option, void* userdata) gAgent.setGenderChosen(TRUE); } -// XUI:translate void dialog_choose_gender_first_start() { if (!gNoRender @@ -3679,13 +3624,6 @@ void release_start_screen() } // static -bool LLStartUp::canGoFullscreen() -{ - return LLStartUp::getStartupState() >= STATE_WORLD_INIT; -} - - -// static void LLStartUp::setStartupState( S32 state ) { llinfos << "Startup state changing from " << gStartupState << " to " << state << llendl; @@ -3706,3 +3644,40 @@ void reset_login() if ( gFloaterMap ) gFloaterMap->setVisible( FALSE ); } + +//--------------------------------------------------------------------------- + +std::string LLStartUp::sSLURLCommand; + +bool LLStartUp::canGoFullscreen() +{ + return gStartupState >= STATE_WORLD_INIT; +} + +bool LLStartUp::dispatchURL() +{ + // ok, if we've gotten this far and have a startup URL + if (!sSLURLCommand.empty()) + { + LLURLDispatcher::dispatch(sSLURLCommand); + } + else if (LLURLSimString::parse()) + { + // If we started with a location, but we're already + // at that location, don't pop dialogs open. + LLVector3 pos = gAgent.getPositionAgent(); + F32 dx = pos.mV[VX] - (F32)LLURLSimString::sInstance.mX; + F32 dy = pos.mV[VY] - (F32)LLURLSimString::sInstance.mY; + const F32 SLOP = 2.f; // meters + + if( LLURLSimString::sInstance.mSimName != gAgent.getRegion()->getName() + || (dx*dx > SLOP*SLOP) + || (dy*dy > SLOP*SLOP) ) + { + std::string url = LLURLSimString::getURL(); + LLURLDispatcher::dispatch(url); + } + return true; + } + return false; +} diff --git a/linden/indra/newview/llstartup.h b/linden/indra/newview/llstartup.h index d9adc62..ad27b28 100644 --- a/linden/indra/newview/llstartup.h +++ b/linden/indra/newview/llstartup.h @@ -2,6 +2,8 @@ * @file llstartup.h * @brief startup routines and logic declaration * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSTARTUP_H @@ -84,6 +87,14 @@ public: static void setStartupState( S32 state ); static S32 getStartupState() { return gStartupState; }; + static bool dispatchURL(); + // if we have a SLURL or sim string ("Ahern/123/45") that started + // the viewer, dispatch it + + static std::string sSLURLCommand; + // *HACK: On startup, if we were passed a secondlife://app/do/foo + // command URL, store it for later processing. + protected: static S32 gStartupState; // Do not set directly, use LLStartup::setStartupState }; diff --git a/linden/indra/newview/llstatbar.cpp b/linden/indra/newview/llstatbar.cpp index 1a8734d..695f8cb 100644 --- a/linden/indra/newview/llstatbar.cpp +++ b/linden/indra/newview/llstatbar.cpp @@ -2,6 +2,8 @@ * @file llstatbar.cpp * @brief A little map of the world with network information * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llstatbar.h b/linden/indra/newview/llstatbar.h index c550b28..6f7e1c1 100644 --- a/linden/indra/newview/llstatbar.h +++ b/linden/indra/newview/llstatbar.h @@ -2,6 +2,8 @@ * @file llstatbar.h * @brief A little map of the world with network information * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSTATBAR_H diff --git a/linden/indra/newview/llstatgraph.cpp b/linden/indra/newview/llstatgraph.cpp index ff43965..bd31077 100644 --- a/linden/indra/newview/llstatgraph.cpp +++ b/linden/indra/newview/llstatgraph.cpp @@ -2,6 +2,8 @@ * @file llstatgraph.cpp * @brief Simpler compact stat graph with tooltip * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llstatgraph.h b/linden/indra/newview/llstatgraph.h index a74a79a..a424d94 100644 --- a/linden/indra/newview/llstatgraph.h +++ b/linden/indra/newview/llstatgraph.h @@ -2,6 +2,8 @@ * @file llstatgraph.h * @brief Simpler compact stat graph with tooltip * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSTATGRAPH_H diff --git a/linden/indra/newview/llstatusbar.cpp b/linden/indra/newview/llstatusbar.cpp index 2471e18..9bbb25f 100644 --- a/linden/indra/newview/llstatusbar.cpp +++ b/linden/indra/newview/llstatusbar.cpp @@ -2,6 +2,8 @@ * @file llstatusbar.cpp * @brief LLStatusBar class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -249,6 +252,8 @@ void LLStatusBar::refresh() mSGBandwidth->setThreshold(1, bwtotal); mSGBandwidth->setThreshold(2, bwtotal); + // *TODO: Localize / translate time + // Get current UTC time, adjusted for the user's clock // being off. U32 utc_time; @@ -282,7 +287,7 @@ void LLStatusBar::refresh() t << std::setfill(' ') << std::setw(2) << hour << ":" << std::setfill('0') << std::setw(2) << min << " " << am_pm << " " << tz; - mTextTime->setText(t.str().c_str()); + mTextTime->setText(t.str()); // Year starts at 1900, set the tooltip to have the date std::ostringstream date; @@ -459,13 +464,13 @@ void LLStatusBar::refresh() pos_y -= pos_y % 2; } - if (parcel && parcel->getName()) + if (parcel && !parcel->getName().empty()) { location_name = region->getName() + llformat(" %d, %d, %d (%s) - %s", pos_x, pos_y, pos_z, region->getSimAccessString(), - parcel->getName()); + parcel->getName().c_str()); } else { @@ -534,10 +539,8 @@ void LLStatusBar::setBalance(S32 balance) void LLStatusBar::setHealth(S32 health) { - char buffer[MAX_STRING]; /* Flawfinder: ignore */ - snprintf(buffer, MAX_STRING, "%d%%", health); /* Flawfinder: ignore */ //llinfos << "Setting health to: " << buffer << llendl; - mTextHealth->setText(buffer); + mTextHealth->setText(llformat("%d%%", health)); if( mHealth > health ) { diff --git a/linden/indra/newview/llstatusbar.h b/linden/indra/newview/llstatusbar.h index ff71ee3..5832dee 100644 --- a/linden/indra/newview/llstatusbar.h +++ b/linden/indra/newview/llstatusbar.h @@ -2,6 +2,8 @@ * @file llstatusbar.h * @brief LLStatusBar class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSTATUSBAR_H diff --git a/linden/indra/newview/llstatview.cpp b/linden/indra/newview/llstatview.cpp index 7a39d96..ac4f17c 100644 --- a/linden/indra/newview/llstatview.cpp +++ b/linden/indra/newview/llstatview.cpp @@ -2,6 +2,8 @@ * @file llstatview.cpp * @brief Container for all statistics info. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llstatview.h b/linden/indra/newview/llstatview.h index 3a885fa..801d583 100644 --- a/linden/indra/newview/llstatview.h +++ b/linden/indra/newview/llstatview.h @@ -2,6 +2,8 @@ * @file llstatview.h * @brief Container for all statistics info. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSTATVIEW_H diff --git a/linden/indra/newview/llsurface.cpp b/linden/indra/newview/llsurface.cpp index 9674802..e9643eb 100644 --- a/linden/indra/newview/llsurface.cpp +++ b/linden/indra/newview/llsurface.cpp @@ -2,6 +2,8 @@ * @file llsurface.cpp * @brief Implementation of LLSurface class * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llsurface.h b/linden/indra/newview/llsurface.h index 0306130..8fecd2d 100644 --- a/linden/indra/newview/llsurface.h +++ b/linden/indra/newview/llsurface.h @@ -2,6 +2,8 @@ * @file llsurface.h * @brief Description of LLSurface class * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSURFACE_H diff --git a/linden/indra/newview/llsurfacepatch.cpp b/linden/indra/newview/llsurfacepatch.cpp index 4452eb1..58f6778 100644 --- a/linden/indra/newview/llsurfacepatch.cpp +++ b/linden/indra/newview/llsurfacepatch.cpp @@ -2,6 +2,8 @@ * @file llsurfacepatch.cpp * @brief LLSurfacePatch class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llsurfacepatch.h b/linden/indra/newview/llsurfacepatch.h index 3e82233..0f91e77 100644 --- a/linden/indra/newview/llsurfacepatch.h +++ b/linden/indra/newview/llsurfacepatch.h @@ -2,6 +2,8 @@ * @file llsurfacepatch.h * @brief LLSurfacePatch class definition * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLSURFACEPATCH_H diff --git a/linden/indra/newview/lltable.h b/linden/indra/newview/lltable.h index d307ad4..7449f2e 100644 --- a/linden/indra/newview/lltable.h +++ b/linden/indra/newview/lltable.h @@ -2,6 +2,8 @@ * @file lltable.h * @brief Description of LLTable template class * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTABLE_H diff --git a/linden/indra/newview/lltexlayer.cpp b/linden/indra/newview/lltexlayer.cpp index 3b48d8b..097682f 100644 --- a/linden/indra/newview/lltexlayer.cpp +++ b/linden/indra/newview/lltexlayer.cpp @@ -2,6 +2,8 @@ * @file lltexlayer.cpp * @brief A texture layer. Used for avatars. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lltexlayer.h b/linden/indra/newview/lltexlayer.h index e5bfb79..458db88 100644 --- a/linden/indra/newview/lltexlayer.h +++ b/linden/indra/newview/lltexlayer.h @@ -2,6 +2,8 @@ * @file lltexlayer.h * @brief A texture layer. Used for avatars. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTEXLAYER_H diff --git a/linden/indra/newview/lltexturecache.cpp b/linden/indra/newview/lltexturecache.cpp index 81b4343..02eff4d 100644 --- a/linden/indra/newview/lltexturecache.cpp +++ b/linden/indra/newview/lltexturecache.cpp @@ -2,6 +2,8 @@ * @file lltexturecache.cpp * @brief Object which handles local texture caching * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lltexturecache.h b/linden/indra/newview/lltexturecache.h index d33c9a6..e3d3fa3 100644 --- a/linden/indra/newview/lltexturecache.h +++ b/linden/indra/newview/lltexturecache.h @@ -2,6 +2,8 @@ * @file lltexturecache.h * @brief Object for managing texture cachees. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTEXTURECACHE_ diff --git a/linden/indra/newview/lltexturectrl.cpp b/linden/indra/newview/lltexturectrl.cpp index 9c64bd3..b961053 100644 --- a/linden/indra/newview/lltexturectrl.cpp +++ b/linden/indra/newview/lltexturectrl.cpp @@ -3,6 +3,8 @@ * @author Richard Nelson, James Cook * @brief LLTextureCtrl class implementation including related functions * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -341,13 +344,12 @@ void LLFloaterTexturePicker::updateImageStats() //RN: have we received header data for this image? if (mTexturep->getWidth(0) > 0 && mTexturep->getHeight(0) > 0) { - std::ostringstream formatted_dims; - formatted_dims << llformat("Dimensions: %d x %d", mTexturep->getWidth(0),mTexturep->getHeight(0)); - mResolutionLabel->setText(formatted_dims.str()); + LLString formatted_dims = llformat("%d x %d", mTexturep->getWidth(0),mTexturep->getHeight(0)); + mResolutionLabel->setTextArg("[DIMENSIONS]", formatted_dims); } else { - mResolutionLabel->setText("Dimensions: unknown"); + mResolutionLabel->setTextArg("[DIMENSIONS]", LLString("[? x ?]")); } if (gAgent.isGodlike()) { @@ -1451,3 +1453,4 @@ BOOL LLToolTexEyedropper::handleHover(S32 x, S32 y, MASK mask) return TRUE; } + diff --git a/linden/indra/newview/lltexturectrl.h b/linden/indra/newview/lltexturectrl.h index 853ca73..cad3980 100644 --- a/linden/indra/newview/lltexturectrl.h +++ b/linden/indra/newview/lltexturectrl.h @@ -3,6 +3,8 @@ * @author Richard Nelson, James Cook * @brief LLTextureCtrl class header file including related functions * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTEXTURECTRL_H diff --git a/linden/indra/newview/lltexturefetch.cpp b/linden/indra/newview/lltexturefetch.cpp index 7bdd98b..7d5e6ab 100644 --- a/linden/indra/newview/lltexturefetch.cpp +++ b/linden/indra/newview/lltexturefetch.cpp @@ -2,6 +2,8 @@ * @file lltexturefetch.cpp * @brief Object which fetches textures from the cache and/or network * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lltexturefetch.h b/linden/indra/newview/lltexturefetch.h index 6bbd830..8ae4f6d 100644 --- a/linden/indra/newview/lltexturefetch.h +++ b/linden/indra/newview/lltexturefetch.h @@ -2,6 +2,8 @@ * @file lltexturefetch.h * @brief Object for managing texture fetches. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTEXTUREFETCH_H diff --git a/linden/indra/newview/lltextureview.cpp b/linden/indra/newview/lltextureview.cpp index 6a24a57..4df5444 100644 --- a/linden/indra/newview/lltextureview.cpp +++ b/linden/indra/newview/lltextureview.cpp @@ -2,6 +2,8 @@ * @file lltextureview.cpp * @brief LLTextureView class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -638,16 +641,20 @@ void LLTextureView::draw() #if 1 if (pri < HIGH_PRIORITY && gSelectMgr) { - S32 te; - LLViewerObject *objectp; - LLObjectSelectionHandle selection = gSelectMgr->getSelection(); - for (selection->getFirstTE(&objectp, &te); objectp; selection->getNextTE(&objectp, &te)) + struct f : public LLSelectedTEFunctor { - if (imagep == objectp->getTEImage(te)) + LLViewerImage* mImage; + f(LLViewerImage* image) : mImage(image) {} + virtual bool apply(LLViewerObject* object, S32 te) { - pri += 3*HIGH_PRIORITY; - break; + return (mImage == object->getTEImage(te)); } + } func(imagep); + const bool firstonly = true; + bool match = gSelectMgr->getSelection()->applyToTEs(&func, firstonly); + if (match) + { + pri += 3*HIGH_PRIORITY; } } #endif diff --git a/linden/indra/newview/lltextureview.h b/linden/indra/newview/lltextureview.h index a838e6c..60bf634 100644 --- a/linden/indra/newview/lltextureview.h +++ b/linden/indra/newview/lltextureview.h @@ -2,6 +2,8 @@ * @file lltextureview.h * @brief LLTextureView class header file * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTEXTUREVIEW_H diff --git a/linden/indra/newview/lltool.cpp b/linden/indra/newview/lltool.cpp index 82d8fb9..cfc3f78 100644 --- a/linden/indra/newview/lltool.cpp +++ b/linden/indra/newview/lltool.cpp @@ -2,6 +2,8 @@ * @file lltool.cpp * @brief LLTool class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lltool.h b/linden/indra/newview/lltool.h index cbed9f7..33dc478 100644 --- a/linden/indra/newview/lltool.h +++ b/linden/indra/newview/lltool.h @@ -2,6 +2,8 @@ * @file lltool.h * @brief LLTool class header file * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTOOL_H diff --git a/linden/indra/newview/lltoolbar.cpp b/linden/indra/newview/lltoolbar.cpp index d58cca0..71e8aec 100644 --- a/linden/indra/newview/lltoolbar.cpp +++ b/linden/indra/newview/lltoolbar.cpp @@ -3,6 +3,8 @@ * @author James Cook, Richard Nelson * @brief Large friendly buttons at bottom of screen. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lltoolbar.h b/linden/indra/newview/lltoolbar.h index 3e32881..c43c80b 100644 --- a/linden/indra/newview/lltoolbar.h +++ b/linden/indra/newview/lltoolbar.h @@ -2,6 +2,8 @@ * @file lltoolbar.h * @brief Large friendly buttons at bottom of screen. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTOOLBAR_H diff --git a/linden/indra/newview/lltoolbrush.cpp b/linden/indra/newview/lltoolbrush.cpp index 98cafa0..a56bf42 100644 --- a/linden/indra/newview/lltoolbrush.cpp +++ b/linden/indra/newview/lltoolbrush.cpp @@ -2,6 +2,8 @@ * @file lltoolbrush.cpp * @brief Implementation of the toolbrushes * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -413,7 +416,7 @@ void LLToolBrushLand::handleSelect() { gEditMenuHandler = this; - gFloaterTools->setStatusText("Click and hold to modify land"); + gFloaterTools->setStatusText("modifyland"); // if (!mBrushSelected) { mLastShowParcelOwners = gSavedSettings.getBOOL("ShowParcelOwners"); @@ -429,7 +432,6 @@ void LLToolBrushLand::handleDeselect() { gEditMenuHandler = NULL; } - gFloaterTools->setStatusText(""); mLastShowParcelOwners = gSavedSettings.getBOOL("ShowParcelOwners"); gSavedSettings.setBOOL("ShowParcelOwners", mLastShowParcelOwners); gParcelMgr->setSelectionVisible(TRUE); diff --git a/linden/indra/newview/lltoolbrush.h b/linden/indra/newview/lltoolbrush.h index 97aa13f..76a361e 100644 --- a/linden/indra/newview/lltoolbrush.h +++ b/linden/indra/newview/lltoolbrush.h @@ -2,6 +2,8 @@ * @file lltoolbrush.h * @brief toolbrush class header file * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTOOLBRUSH_H diff --git a/linden/indra/newview/lltoolcomp.cpp b/linden/indra/newview/lltoolcomp.cpp index 555f25e..182ea56 100644 --- a/linden/indra/newview/lltoolcomp.cpp +++ b/linden/indra/newview/lltoolcomp.cpp @@ -2,6 +2,8 @@ * @file lltoolcomp.cpp * @brief Composite tools * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -247,11 +250,7 @@ void LLToolCompTranslate::pickCallback(S32 x, S32 y, MASK mask) gEditMenuHandler = gSelectMgr; } - BOOL can_move = gToolTranslate->mManip->getSelection()->getObjectCount() != 0; - for (LLViewerObject* objectp = gToolTranslate->mManip->getSelection()->getFirstObject(); objectp; objectp = gToolTranslate->mManip->getSelection()->getNextObject()) - { - can_move = can_move && objectp->permMove() && (objectp->permModify() || !gSavedSettings.getBOOL("EditLinkedParts")); - } + BOOL can_move = gToolTranslate->mManip->canAffectSelection(); if( LLManip::LL_NO_PART != gToolTranslate->mManip->getHighlightedPart() && can_move) { diff --git a/linden/indra/newview/lltoolcomp.h b/linden/indra/newview/lltoolcomp.h index 029437c..5dacfbb 100644 --- a/linden/indra/newview/lltoolcomp.h +++ b/linden/indra/newview/lltoolcomp.h @@ -2,6 +2,8 @@ * @file lltoolcomp.h * @brief Composite tools * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_TOOLCOMP_H diff --git a/linden/indra/newview/lltooldraganddrop.cpp b/linden/indra/newview/lltooldraganddrop.cpp index 655a8dd..0be4212 100644 --- a/linden/indra/newview/lltooldraganddrop.cpp +++ b/linden/indra/newview/lltooldraganddrop.cpp @@ -2,6 +2,8 @@ * @file lltooldraganddrop.cpp * @brief LLToolDragAndDrop class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lltooldraganddrop.h b/linden/indra/newview/lltooldraganddrop.h index 4f66f7d..5da4e63 100644 --- a/linden/indra/newview/lltooldraganddrop.h +++ b/linden/indra/newview/lltooldraganddrop.h @@ -2,6 +2,8 @@ * @file lltooldraganddrop.h * @brief LLToolDragAndDrop class header file * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_TOOLDRAGANDDROP_H diff --git a/linden/indra/newview/lltoolface.cpp b/linden/indra/newview/lltoolface.cpp index 276d921..1959982 100644 --- a/linden/indra/newview/lltoolface.cpp +++ b/linden/indra/newview/lltoolface.cpp @@ -2,6 +2,8 @@ * @file lltoolface.cpp * @brief A tool to manipulate faces * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lltoolface.h b/linden/indra/newview/lltoolface.h index daf82b1..c752498 100644 --- a/linden/indra/newview/lltoolface.h +++ b/linden/indra/newview/lltoolface.h @@ -2,6 +2,8 @@ * @file lltoolface.h * @brief A tool to select object faces * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTOOLFACE_H diff --git a/linden/indra/newview/lltoolfocus.cpp b/linden/indra/newview/lltoolfocus.cpp index 733a47e..2ac2b33 100644 --- a/linden/indra/newview/lltoolfocus.cpp +++ b/linden/indra/newview/lltoolfocus.cpp @@ -2,6 +2,8 @@ * @file lltoolfocus.cpp * @brief A tool to set the build focus point. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -91,17 +94,13 @@ void LLToolCamera::handleSelect() { if (gFloaterTools) { - gFloaterTools->setStatusText("Click and drag to change view"); + gFloaterTools->setStatusText("camera"); } } // virtual void LLToolCamera::handleDeselect() { - if (gFloaterTools) - { - gFloaterTools->setStatusText(""); - } // gAgent.setLookingAtAvatar(FALSE); } @@ -282,9 +281,11 @@ BOOL LLToolCamera::handleMouseUp(S32 x, S32 y, MASK mask) { LLCoordGL mouse_pos; LLVector3 focus_pos = gAgent.getPosAgentFromGlobal(gAgent.getFocusGlobal()); - gCamera->projectPosAgentToScreen(focus_pos, mouse_pos); - - LLUI::setCursorPositionScreen(mouse_pos.mX, mouse_pos.mY); + BOOL success = gCamera->projectPosAgentToScreen(focus_pos, mouse_pos); + if (success) + { + LLUI::setCursorPositionScreen(mouse_pos.mX, mouse_pos.mY); + } } else if (mMouseSteering) { diff --git a/linden/indra/newview/lltoolfocus.h b/linden/indra/newview/lltoolfocus.h index b16fe81..ff2e690 100644 --- a/linden/indra/newview/lltoolfocus.h +++ b/linden/indra/newview/lltoolfocus.h @@ -2,6 +2,8 @@ * @file lltoolfocus.h * @brief A tool to set the build focus point. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTOOLFOCUS_H diff --git a/linden/indra/newview/lltoolgrab.cpp b/linden/indra/newview/lltoolgrab.cpp index e79121a..13977ee 100644 --- a/linden/indra/newview/lltoolgrab.cpp +++ b/linden/indra/newview/lltoolgrab.cpp @@ -2,6 +2,8 @@ * @file lltoolgrab.cpp * @brief LLToolGrab class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -98,7 +101,7 @@ void LLToolGrab::handleSelect() if(gFloaterTools) { // viewer can crash during startup if we don't check. - gFloaterTools->setStatusText("Drag to move objects, Ctrl to lift, Ctrl-Shift to spin"); + gFloaterTools->setStatusText("grab"); } gGrabBtnVertical = FALSE; gGrabBtnSpin = FALSE; @@ -111,7 +114,6 @@ void LLToolGrab::handleDeselect() setMouseCapture( FALSE ); } - gFloaterTools->setStatusText(""); } BOOL LLToolGrab::handleDoubleClick(S32 x, S32 y, MASK mask) diff --git a/linden/indra/newview/lltoolgrab.h b/linden/indra/newview/lltoolgrab.h index 7919c0d..af0c7de 100644 --- a/linden/indra/newview/lltoolgrab.h +++ b/linden/indra/newview/lltoolgrab.h @@ -2,6 +2,8 @@ * @file lltoolgrab.h * @brief LLToolGrab class header file * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_TOOLGRAB_H diff --git a/linden/indra/newview/lltoolgun.cpp b/linden/indra/newview/lltoolgun.cpp index d442d81..c7e598e 100644 --- a/linden/indra/newview/lltoolgun.cpp +++ b/linden/indra/newview/lltoolgun.cpp @@ -2,6 +2,8 @@ * @file lltoolgun.cpp * @brief LLToolGun class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lltoolgun.h b/linden/indra/newview/lltoolgun.h index 93b0b5b..14cc502 100644 --- a/linden/indra/newview/lltoolgun.h +++ b/linden/indra/newview/lltoolgun.h @@ -2,6 +2,8 @@ * @file lltoolgun.h * @brief LLToolGun class header file * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_TOOLGUN_H diff --git a/linden/indra/newview/lltoolindividual.cpp b/linden/indra/newview/lltoolindividual.cpp index 3bcc210..3ec6b7d 100644 --- a/linden/indra/newview/lltoolindividual.cpp +++ b/linden/indra/newview/lltoolindividual.cpp @@ -2,6 +2,8 @@ * @file lltoolindividual.cpp * @brief LLToolIndividual class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //***************************************************************************** @@ -105,11 +108,8 @@ BOOL LLToolIndividual::handleDoubleClick(S32 x, S32 y, MASK mask) void LLToolIndividual::handleSelect() { - LLViewerObject* obj = gSelectMgr->getSelection()->getFirstRootObject(); - if(!obj) - { - obj = gSelectMgr->getSelection()->getFirstObject(); - } + const BOOL children_ok = TRUE; + LLViewerObject* obj = gSelectMgr->getSelection()->getFirstRootObject(children_ok); gSelectMgr->deselectAll(); if(obj) { diff --git a/linden/indra/newview/lltoolindividual.h b/linden/indra/newview/lltoolindividual.h index e6f0df9..e5636dd 100644 --- a/linden/indra/newview/lltoolindividual.h +++ b/linden/indra/newview/lltoolindividual.h @@ -2,6 +2,8 @@ * @file lltoolindividual.h * @brief LLToolIndividual class header file * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTOOLINDIVIDUAL_H diff --git a/linden/indra/newview/lltoolmgr.cpp b/linden/indra/newview/lltoolmgr.cpp index 8ce8111..ae74eba 100644 --- a/linden/indra/newview/lltoolmgr.cpp +++ b/linden/indra/newview/lltoolmgr.cpp @@ -2,6 +2,8 @@ * @file lltoolmgr.cpp * @brief LLToolMgr class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -335,18 +338,21 @@ LLTool* LLToolMgr::getCurrentTool() cur_tool = mOverrideTool ? mOverrideTool : mBaseTool; } + LLTool* prev_tool = mSelectedTool; + // Set the selected tool to avoid infinite recursion + mSelectedTool = cur_tool; + //update tool selection status - if (mSelectedTool != cur_tool) + if (prev_tool != cur_tool) { - if (mSelectedTool) + if (prev_tool) { - mSelectedTool->handleDeselect(); + prev_tool->handleDeselect(); } if (cur_tool) { cur_tool->handleSelect(); } - mSelectedTool = cur_tool; } return mSelectedTool; diff --git a/linden/indra/newview/lltoolmgr.h b/linden/indra/newview/lltoolmgr.h index e61bbc3..e0f554d 100644 --- a/linden/indra/newview/lltoolmgr.h +++ b/linden/indra/newview/lltoolmgr.h @@ -2,6 +2,8 @@ * @file lltoolmgr.h * @brief LLToolMgr class header file * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_TOOLMGR_H diff --git a/linden/indra/newview/lltoolmorph.cpp b/linden/indra/newview/lltoolmorph.cpp index 25d7d2e..d3cd997 100644 --- a/linden/indra/newview/lltoolmorph.cpp +++ b/linden/indra/newview/lltoolmorph.cpp @@ -2,6 +2,8 @@ * @file lltoolmorph.cpp * @brief A tool to manipulate faces.. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lltoolmorph.h b/linden/indra/newview/lltoolmorph.h index 35ee724..72e73b0 100644 --- a/linden/indra/newview/lltoolmorph.h +++ b/linden/indra/newview/lltoolmorph.h @@ -2,6 +2,8 @@ * @file lltoolmorph.h * @brief A tool to select object faces. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTOOLMORPH_H diff --git a/linden/indra/newview/lltoolobjpicker.cpp b/linden/indra/newview/lltoolobjpicker.cpp index 411bdc0..8e8abfe 100644 --- a/linden/indra/newview/lltoolobjpicker.cpp +++ b/linden/indra/newview/lltoolobjpicker.cpp @@ -2,6 +2,8 @@ * @file lltoolobjpicker.cpp * @brief LLToolObjPicker class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // LLToolObjPicker is a transient tool, useful for a single object pick. diff --git a/linden/indra/newview/lltoolobjpicker.h b/linden/indra/newview/lltoolobjpicker.h index 7a73304..985ce14 100644 --- a/linden/indra/newview/lltoolobjpicker.h +++ b/linden/indra/newview/lltoolobjpicker.h @@ -2,6 +2,8 @@ * @file lltoolobjpicker.h * @brief LLToolObjPicker class header file * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_TOOLOBJPICKER_H diff --git a/linden/indra/newview/lltoolpie.cpp b/linden/indra/newview/lltoolpie.cpp index 0aa7d10..55692d1 100644 --- a/linden/indra/newview/lltoolpie.cpp +++ b/linden/indra/newview/lltoolpie.cpp @@ -2,6 +2,8 @@ * @file lltoolpie.cpp * @brief LLToolPie class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -307,12 +310,12 @@ BOOL LLToolPie::pickAndShowMenu(S32 x, S32 y, MASK mask, BOOL always_show) LLString name = avatar->getFullname(); if (gMuteListp->isMuted(avatar->getID(), name)) { - gMenuHolder->childSetText("Avatar Mute", "Unmute"); + gMenuHolder->childSetText("Avatar Mute", LLString("Unmute")); // *TODO:Translate //gMutePieMenu->setLabel("Unmute"); } else { - gMenuHolder->childSetText("Avatar Mute", "Mute"); + gMenuHolder->childSetText("Avatar Mute", LLString("Mute")); // *TODO:Translate //gMutePieMenu->setLabel("Mute"); } @@ -333,12 +336,12 @@ BOOL LLToolPie::pickAndShowMenu(S32 x, S32 y, MASK mask, BOOL always_show) } if (gMuteListp->isMuted(object->getID(), name)) { - gMenuHolder->childSetText("Object Mute", "Unmute"); + gMenuHolder->childSetText("Object Mute", LLString("Unmute")); // *TODO:Translate //gMuteObjectPieMenu->setLabel("Unmute"); } else { - gMenuHolder->childSetText("Object Mute", "Mute"); + gMenuHolder->childSetText("Object Mute", LLString("Mute")); // *TODO:Translate //gMuteObjectPieMenu->setLabel("Mute"); } @@ -672,3 +675,4 @@ void LLToolPie::render() return; } + diff --git a/linden/indra/newview/lltoolpie.h b/linden/indra/newview/lltoolpie.h index 2fba989..ffc2fb9 100644 --- a/linden/indra/newview/lltoolpie.h +++ b/linden/indra/newview/lltoolpie.h @@ -2,6 +2,8 @@ * @file lltoolpie.h * @brief LLToolPie class header file * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_TOOLPIE_H diff --git a/linden/indra/newview/lltoolpipette.cpp b/linden/indra/newview/lltoolpipette.cpp index 139afc2..bcddd58 100644 --- a/linden/indra/newview/lltoolpipette.cpp +++ b/linden/indra/newview/lltoolpipette.cpp @@ -2,6 +2,8 @@ * @file lltoolpipette.cpp * @brief LLToolPipette class implementation * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /** diff --git a/linden/indra/newview/lltoolpipette.h b/linden/indra/newview/lltoolpipette.h index 1351084..411cb46 100644 --- a/linden/indra/newview/lltoolpipette.h +++ b/linden/indra/newview/lltoolpipette.h @@ -2,6 +2,8 @@ * @file lltoolpipette.h * @brief LLToolPipette class header file * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // A tool to pick texture entry infro from objects in world (color/texture) diff --git a/linden/indra/newview/lltoolplacer.cpp b/linden/indra/newview/lltoolplacer.cpp index 9741602..ee5d08f 100644 --- a/linden/indra/newview/lltoolplacer.cpp +++ b/linden/indra/newview/lltoolplacer.cpp @@ -2,6 +2,8 @@ * @file lltoolplacer.cpp * @brief Tool for placing new objects into the world * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -145,12 +148,11 @@ BOOL LLToolPlacer::handleHover(S32 x, S32 y, MASK mask) void LLToolPlacer::handleSelect() { - gFloaterTools->setStatusText("Click in the world to create, shift-click to select"); + gFloaterTools->setStatusText("place"); } void LLToolPlacer::handleDeselect() { - gFloaterTools->setStatusText(""); } ////////////////////////////////////////////////////// diff --git a/linden/indra/newview/lltoolplacer.h b/linden/indra/newview/lltoolplacer.h index 914f99d..d6d21cb 100644 --- a/linden/indra/newview/lltoolplacer.h +++ b/linden/indra/newview/lltoolplacer.h @@ -2,6 +2,8 @@ * @file lltoolplacer.h * @brief Tool for placing new objects into the world * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_TOOLPLACER_H diff --git a/linden/indra/newview/lltoolselect.cpp b/linden/indra/newview/lltoolselect.cpp index f400b53..f77202f 100644 --- a/linden/indra/newview/lltoolselect.cpp +++ b/linden/indra/newview/lltoolselect.cpp @@ -2,6 +2,8 @@ * @file lltoolselect.cpp * @brief LLToolSelect class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -152,6 +155,11 @@ LLHandle LLToolSelect::handleObjectSelection(LLViewerObject * } else { + // Save the current zoom values because deselect resets them. + F32 target_zoom; + F32 current_zoom; + gSelectMgr->getAgentHUDZoom(target_zoom, current_zoom); + // JC - Change behavior to make it easier to select children // of linked sets. 9/3/2002 if( !already_selected || ignore_group) @@ -168,6 +176,9 @@ LLHandle LLToolSelect::handleObjectSelection(LLViewerObject * { gSelectMgr->selectObjectAndFamily(object); } + + // restore the zoom to the previously stored values. + gSelectMgr->setAgentHUDZoom(target_zoom, current_zoom); } if (!gAgent.getFocusOnAvatar() && // if camera not glued to avatar diff --git a/linden/indra/newview/lltoolselect.h b/linden/indra/newview/lltoolselect.h index 2e24bc4..bbf3529 100644 --- a/linden/indra/newview/lltoolselect.h +++ b/linden/indra/newview/lltoolselect.h @@ -2,6 +2,8 @@ * @file lltoolselect.h * @brief LLToolSelect class header file * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_TOOLSELECT_H diff --git a/linden/indra/newview/lltoolselectland.cpp b/linden/indra/newview/lltoolselectland.cpp index 3f0d7ba..dae8288 100644 --- a/linden/indra/newview/lltoolselectland.cpp +++ b/linden/indra/newview/lltoolselectland.cpp @@ -2,6 +2,8 @@ * @file lltoolselectland.cpp * @brief LLToolSelectLand class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -216,7 +219,7 @@ void LLToolSelectLand::render() void LLToolSelectLand::handleSelect() { - gFloaterTools->setStatusText("Click and drag to select land"); + gFloaterTools->setStatusText("selectland"); mLastShowParcelOwners = gSavedSettings.getBOOL("ShowParcelOwners"); gSavedSettings.setBOOL("ShowParcelOwners", mLastShowParcelOwners); } @@ -224,7 +227,6 @@ void LLToolSelectLand::handleSelect() void LLToolSelectLand::handleDeselect() { - gFloaterTools->setStatusText(""); mSelection = NULL; mLastShowParcelOwners = gSavedSettings.getBOOL("ShowParcelOwners"); //gParcelMgr->deselectLand(); diff --git a/linden/indra/newview/lltoolselectland.h b/linden/indra/newview/lltoolselectland.h index 3412d41..8abcdc3 100644 --- a/linden/indra/newview/lltoolselectland.h +++ b/linden/indra/newview/lltoolselectland.h @@ -2,6 +2,8 @@ * @file lltoolselectland.h * @brief LLToolSelectLand class header file * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTOOLSELECTLAND_H diff --git a/linden/indra/newview/lltoolselectrect.cpp b/linden/indra/newview/lltoolselectrect.cpp index 4e9bc9e..505039d 100644 --- a/linden/indra/newview/lltoolselectrect.cpp +++ b/linden/indra/newview/lltoolselectrect.cpp @@ -2,6 +2,8 @@ * @file lltoolselectrect.cpp * @brief A tool to select multiple objects with a screen-space rectangle. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lltoolselectrect.h b/linden/indra/newview/lltoolselectrect.h index e246178..d45f0a4 100644 --- a/linden/indra/newview/lltoolselectrect.h +++ b/linden/indra/newview/lltoolselectrect.h @@ -2,6 +2,8 @@ * @file lltoolselectrect.h * @brief A tool to select multiple objects with a screen-space rectangle. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTOOLSELECTRECT_H diff --git a/linden/indra/newview/lltoolview.cpp b/linden/indra/newview/lltoolview.cpp index 76de2e2..b3f0dc4 100644 --- a/linden/indra/newview/lltoolview.cpp +++ b/linden/indra/newview/lltoolview.cpp @@ -2,6 +2,8 @@ * @file lltoolview.cpp * @brief A UI contains for tool palette tools * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -72,7 +75,7 @@ LLToolView::~LLToolView() mContainList.deleteAllData(); } -//XUI: translate +//*TODO:translate? void LLToolView::addTool(const LLString& icon_off, const LLString& icon_on, LLPanel* panel, LLTool* tool, LLView* hoverView, const char* label) { llassert(tool); @@ -192,3 +195,4 @@ void LLToolView::onClickToolButton(void* userdata) gToolMgr->getCurrentToolset()->selectTool( clicked->mTool ); } + diff --git a/linden/indra/newview/lltoolview.h b/linden/indra/newview/lltoolview.h index 749f9fe..bde0010 100644 --- a/linden/indra/newview/lltoolview.h +++ b/linden/indra/newview/lltoolview.h @@ -2,6 +2,8 @@ * @file lltoolview.h * @brief UI container for tools. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLTOOLVIEW_H diff --git a/linden/indra/newview/lltracker.cpp b/linden/indra/newview/lltracker.cpp index 4125bb6..a35d7b5 100644 --- a/linden/indra/newview/lltracker.cpp +++ b/linden/indra/newview/lltracker.cpp @@ -2,6 +2,8 @@ * @file lltracker.cpp * @brief Container for objects user is tracking. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lltracker.h b/linden/indra/newview/lltracker.h index e8299f7..c7e09d0 100644 --- a/linden/indra/newview/lltracker.h +++ b/linden/indra/newview/lltracker.h @@ -2,6 +2,8 @@ * @file lltracker.h * @brief Container for objects user is tracking. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // A singleton class for tracking stuff. diff --git a/linden/indra/newview/lluiconstants.h b/linden/indra/newview/lluiconstants.h index a51267a..9e50696 100644 --- a/linden/indra/newview/lluiconstants.h +++ b/linden/indra/newview/lluiconstants.h @@ -2,6 +2,8 @@ * @file lluiconstants.h * @brief Compile-time configuration for UI * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLUICONSTANTS_H diff --git a/linden/indra/newview/lluploaddialog.cpp b/linden/indra/newview/lluploaddialog.cpp index fc4f188..a63f546 100644 --- a/linden/indra/newview/lluploaddialog.cpp +++ b/linden/indra/newview/lluploaddialog.cpp @@ -2,6 +2,8 @@ * @file lluploaddialog.cpp * @brief LLUploadDialog class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/lluploaddialog.h b/linden/indra/newview/lluploaddialog.h index 51f5d83..b975fd5 100644 --- a/linden/indra/newview/lluploaddialog.h +++ b/linden/indra/newview/lluploaddialog.h @@ -2,6 +2,8 @@ * @file lluploaddialog.h * @brief LLUploadDialog class header file * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_UPLOADDIALOG_H diff --git a/linden/indra/newview/llurl.cpp b/linden/indra/newview/llurl.cpp index a429b67..454dd50 100644 --- a/linden/indra/newview/llurl.cpp +++ b/linden/indra/newview/llurl.cpp @@ -2,6 +2,8 @@ * @file llurl.cpp * @brief Text url class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,10 +26,10 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" -#include #include "llurl.h" #include "llerror.h" diff --git a/linden/indra/newview/llurl.h b/linden/indra/newview/llurl.h index 4dc8cfc..99f93b9 100644 --- a/linden/indra/newview/llurl.h +++ b/linden/indra/newview/llurl.h @@ -2,6 +2,8 @@ * @file llurl.h * @brief Text url class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLURL_H diff --git a/linden/indra/newview/llurldispatcher.cpp b/linden/indra/newview/llurldispatcher.cpp new file mode 100644 index 0000000..7344206 --- /dev/null +++ b/linden/indra/newview/llurldispatcher.cpp @@ -0,0 +1,326 @@ +/** + * @file llurldispatcher.cpp + * @brief Central registry for all URL handlers + * + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. + * + * Second Life Viewer Source Code + * The source code in this file ("Source Code") is provided by Linden Lab + * to you under the terms of the GNU General Public License, version 2.0 + * ("GPL"), unless you have obtained a separate licensing agreement + * ("Other License"), formally executed by you and Linden Lab. Terms of + * the GPL can be found in doc/GPL-license.txt in this distribution, or + * online at http://secondlife.com/developers/opensource/gplv2 + * + * There are special exceptions to the terms and conditions of the GPL as + * it is applied to this Source Code. View the full text of the exception + * in the file doc/FLOSS-exception.txt in this software distribution, or + * online at http://secondlife.com/developers/opensource/flossexception + * + * By copying, modifying or distributing this software, you acknowledge + * that you have read and understood your obligations described above, + * and agree to abide by those obligations. + * + * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO + * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, + * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ + */ +#include "llviewerprecompiledheaders.h" + +#include "llurldispatcher.h" + +// viewer includes +#include "llagent.h" // teleportViaLocation() +#include "llcommandhandler.h" +// *FIX: code in merge sl-search-8 +//#include "llfloaterurldisplay.h" +#include "llfloaterdirectory.h" +#include "llfloaterhtmlhelp.h" +#include "llfloaterworldmap.h" +#include "llpanellogin.h" +#include "llstartup.h" // gStartupState +#include "llurlsimstring.h" +#include "llviewerwindow.h" // alertXml() +#include "llworldmap.h" + +// library includes +#include "llsd.h" + +// system includes +#include + +const std::string SLURL_SL_HELP_PREFIX = "secondlife://app."; +const std::string SLURL_SL_PREFIX = "sl://"; +const std::string SLURL_SECONDLIFE_PREFIX = "secondlife://"; +const std::string SLURL_SLURL_PREFIX = "http://slurl.com/secondlife/"; + +const std::string SLURL_APP_TOKEN = "app/"; + +class LLURLDispatcherImpl +{ +public: + static bool isSLURL(const std::string& url); + + static bool isSLURLCommand(const std::string& url); + + static bool dispatch(const std::string& url); + // returns true if handled + + static bool dispatchRightClick(const std::string& url); + +private: + static bool dispatchCore(const std::string& url, bool right_mouse); + // handles both left and right click + + static bool dispatchHelp(const std::string& url, BOOL right_mouse); + // Handles sl://app.floater.html.help by showing Help floater. + // Returns true if handled. + + static bool dispatchApp(const std::string& url, BOOL right_mouse); + // Handles secondlife://app/agent//about and similar + // by showing panel in Search floater. + // Returns true if handled. + + static bool dispatchRegion(const std::string& url, BOOL right_mouse); + // handles secondlife://Ahern/123/45/67/ + // Returns true if handled. + +// *FIX: code in merge sl-search-8 +// static void regionHandleCallback(U64 handle, const std::string& url, +// const LLUUID& snapshot_id, bool teleport); +// // Called by LLWorldMap when a region name has been resolved to a +// // location in-world, used by places-panel display. + + static bool matchPrefix(const std::string& url, const std::string& prefix); + + static std::string stripProtocol(const std::string& url); + + friend class LLTeleportHandler; +}; + +// static +bool LLURLDispatcherImpl::isSLURL(const std::string& url) +{ + if (matchPrefix(url, SLURL_SL_HELP_PREFIX)) return true; + if (matchPrefix(url, SLURL_SL_PREFIX)) return true; + if (matchPrefix(url, SLURL_SECONDLIFE_PREFIX)) return true; + if (matchPrefix(url, SLURL_SLURL_PREFIX)) return true; + return false; +} + +// static +bool LLURLDispatcherImpl::isSLURLCommand(const std::string& url) +{ + if (matchPrefix(url, SLURL_SL_PREFIX + SLURL_APP_TOKEN) + || matchPrefix(url, SLURL_SECONDLIFE_PREFIX + SLURL_APP_TOKEN) + || matchPrefix(url, SLURL_SLURL_PREFIX + SLURL_APP_TOKEN) ) + { + return true; + } + return false; +} + +// static +bool LLURLDispatcherImpl::dispatchCore(const std::string& url, bool right_mouse) +{ + if (url.empty()) return false; + if (dispatchHelp(url, right_mouse)) return true; + if (dispatchApp(url, right_mouse)) return true; + if (dispatchRegion(url, right_mouse)) return true; + return false; +} + +// static +bool LLURLDispatcherImpl::dispatch(const std::string& url) +{ + llinfos << "url: " << url << llendl; + return dispatchCore(url, false); // not right click +} + +// static +bool LLURLDispatcherImpl::dispatchRightClick(const std::string& url) +{ + llinfos << "url: " << url << llendl; + return dispatchCore(url, true); // yes right click +} +// static +bool LLURLDispatcherImpl::dispatchHelp(const std::string& url, BOOL right_mouse) +{ + if (matchPrefix(url, SLURL_SL_HELP_PREFIX)) + { + gViewerHtmlHelp.show(); + return true; + } + return false; +} + +// static +bool LLURLDispatcherImpl::dispatchApp(const std::string& url, BOOL right_mouse) +{ + if (!isSLURL(url)) + { + return false; + } + std::string s = stripProtocol(url); + + // At this point, "secondlife://app/foo/bar/baz/" should be left + // as: "app/foo/bar/baz/" + typedef boost::tokenizer > tokenizer; + boost::char_separator sep("/", "", boost::drop_empty_tokens); + tokenizer tokens(s, sep); + tokenizer::iterator it = tokens.begin(); + tokenizer::iterator end = tokens.end(); + + // Build parameter list suitable for LLDispatcher dispatch + if (it == end) return false; + if (*it != "app") return false; + ++it; + + if (it == end) return false; + std::string cmd = *it; + ++it; + + std::vector params; + for ( ; it != end; ++it) + { + params.push_back(*it); + } + + bool handled = LLCommandDispatcher::dispatch(cmd, params); + if (handled) return true; + + // Inform the user we can't handle this + std::map args; + args["[SLURL]"] = url; + gViewerWindow->alertXml("BadURL", args); + return false; +} + +// static +bool LLURLDispatcherImpl::dispatchRegion(const std::string& url, BOOL right_mouse) +{ + if (!isSLURL(url)) + { + return false; + } + + // Before we're logged in, need to update the startup screen + // to tell the user where they are going. + if (LLStartUp::getStartupState() < STATE_CLEANUP) + { + // Parse it and stash in globals, it will be dispatched in + // STATE_CLEANUP. + LLURLSimString::setString(url); + // We're at the login screen, so make sure user can see + // the login location box to know where they are going. + LLPanelLogin::refreshLocation( true ); + return true; + } + + std::string sim_string = stripProtocol(url); + std::string region_name; + S32 x = 128; + S32 y = 128; + S32 z = 0; + LLURLSimString::parse(sim_string, ®ion_name, &x, &y, &z); + if (gFloaterWorldMap) + { + llinfos << "Opening map to " << region_name << llendl; + gFloaterWorldMap->trackURL( region_name.c_str(), x, y, z ); + LLFloaterWorldMap::show(NULL, TRUE); + } + return true; +} + +// static +bool LLURLDispatcherImpl::matchPrefix(const std::string& url, const std::string& prefix) +{ + std::string test_prefix = url.substr(0, prefix.length()); + LLString::toLower(test_prefix); + return test_prefix == prefix; +} + +// static +std::string LLURLDispatcherImpl::stripProtocol(const std::string& url) +{ + std::string stripped = url; + if (matchPrefix(stripped, SLURL_SL_HELP_PREFIX)) + { + stripped.erase(0, SLURL_SL_HELP_PREFIX.length()); + } + else if (matchPrefix(stripped, SLURL_SL_PREFIX)) + { + stripped.erase(0, SLURL_SL_PREFIX.length()); + } + else if (matchPrefix(stripped, SLURL_SECONDLIFE_PREFIX)) + { + stripped.erase(0, SLURL_SECONDLIFE_PREFIX.length()); + } + else if (matchPrefix(stripped, SLURL_SLURL_PREFIX)) + { + stripped.erase(0, SLURL_SLURL_PREFIX.length()); + } + return stripped; +} + +// *FIX: code in merge sl-search-8 +// +////--------------------------------------------------------------------------- +//// Teleportation links are handled here because they are tightly coupled +//// to URL parsing and sim-fragment parsing +//class LLTeleportHandler : public LLCommandHandler +//{ +//public: +// LLTeleportHandler() : LLCommandHandler("teleport") { } +// bool handle(const std::vector& tokens) +// { +// // construct a "normal" SLURL, resolve the region to +// // a global position, and teleport to it +// if (tokens.size() < 1) return false; +// +// // Region names may be %20 escaped. +// std::string region_name = LLURLSimString::unescapeRegionName(tokens[0]); +// +// // build secondlife://De%20Haro/123/45/67 for use in callback +// std::string url = SLURL_SECONDLIFE_PREFIX; +// for (size_t i = 0; i < tokens.size(); ++i) +// { +// url += tokens[i] + "/"; +// } +// gWorldMap->sendNamedRegionRequest(region_name, +// LLURLDispatcherImpl::regionHandleCallback, +// url, +// true); // teleport +// return true; +// } +//}; +//LLTeleportHandler gTeleportHandler; + +//--------------------------------------------------------------------------- + +// static +bool LLURLDispatcher::isSLURL(const std::string& url) +{ + return LLURLDispatcherImpl::isSLURL(url); +} + +// static +bool LLURLDispatcher::isSLURLCommand(const std::string& url) +{ + return LLURLDispatcherImpl::isSLURLCommand(url); +} + +// static +bool LLURLDispatcher::dispatch(const std::string& url) +{ + return LLURLDispatcherImpl::dispatch(url); +} +// static +bool LLURLDispatcher::dispatchRightClick(const std::string& url) +{ + return LLURLDispatcherImpl::dispatchRightClick(url); +} + diff --git a/linden/indra/newview/llurldispatcher.h b/linden/indra/newview/llurldispatcher.h new file mode 100644 index 0000000..74b7f87 --- /dev/null +++ b/linden/indra/newview/llurldispatcher.h @@ -0,0 +1,55 @@ +/** + * @file llurldispatcher.h + * @brief Central registry for all SL URL handlers + * + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. + * + * Second Life Viewer Source Code + * The source code in this file ("Source Code") is provided by Linden Lab + * to you under the terms of the GNU General Public License, version 2.0 + * ("GPL"), unless you have obtained a separate licensing agreement + * ("Other License"), formally executed by you and Linden Lab. Terms of + * the GPL can be found in doc/GPL-license.txt in this distribution, or + * online at http://secondlife.com/developers/opensource/gplv2 + * + * There are special exceptions to the terms and conditions of the GPL as + * it is applied to this Source Code. View the full text of the exception + * in the file doc/FLOSS-exception.txt in this software distribution, or + * online at http://secondlife.com/developers/opensource/flossexception + * + * By copying, modifying or distributing this software, you acknowledge + * that you have read and understood your obligations described above, + * and agree to abide by those obligations. + * + * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO + * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, + * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ + */ +#ifndef LLURLDISPATCHER_H +#define LLURLDISPATCHER_H + +class LLURLDispatcher +{ +public: + static bool isSLURL(const std::string& url); + // Is this any sort of secondlife:// or sl:// URL? + + static bool isSLURLCommand(const std::string& url); + // Is this a special secondlife://app/ URL? + + static bool dispatch(const std::string& url); + // At startup time and on clicks in internal web browsers, + // teleport, open map, or run requested command. + // Handles: + // secondlife://RegionName/123/45/67/ + // secondlife://app/agent/3d6181b0-6a4b-97ef-18d8-722652995cf1/show + // sl://app/foo/bar + // Returns true if someone handled the URL. + static bool dispatchRightClick(const std::string& url); + +}; + +#endif diff --git a/linden/indra/newview/llurlsimstring.cpp b/linden/indra/newview/llurlsimstring.cpp new file mode 100644 index 0000000..efa3c5a --- /dev/null +++ b/linden/indra/newview/llurlsimstring.cpp @@ -0,0 +1,171 @@ +/** + * @file llsimurlstring.cpp + * @brief Handles "SLURL fragments" like Ahern/123/45 for + * startup processing, login screen, prefs, etc. + * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * + * Copyright (c) 2006-2007, Linden Research, Inc. + * + * Second Life Viewer Source Code + * The source code in this file ("Source Code") is provided by Linden Lab + * to you under the terms of the GNU General Public License, version 2.0 + * ("GPL"), unless you have obtained a separate licensing agreement + * ("Other License"), formally executed by you and Linden Lab. Terms of + * the GPL can be found in doc/GPL-license.txt in this distribution, or + * online at http://secondlife.com/developers/opensource/gplv2 + * + * There are special exceptions to the terms and conditions of the GPL as + * it is applied to this Source Code. View the full text of the exception + * in the file doc/FLOSS-exception.txt in this software distribution, or + * online at http://secondlife.com/developers/opensource/flossexception + * + * By copying, modifying or distributing this software, you acknowledge + * that you have read and understood your obligations described above, + * and agree to abide by those obligations. + * + * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO + * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, + * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ + */ + +#include "llviewerprecompiledheaders.h" + +#include "llurlsimstring.h" + +#include "llpanellogin.h" +#include "llviewercontrol.h" + +#include "curl/curl.h" + +//static +LLURLSimString LLURLSimString::sInstance; +LLString LLURLSimString::sLocationStringHome("My Home"); +LLString LLURLSimString::sLocationStringLast("My Last Location"); + +// "secondlife://simname/x/y/z" -> "simname/x/y/z" +// (actually .*//foo -> foo) +// static +void LLURLSimString::setString(const LLString& sim_string) +{ + sInstance.mSimString.clear(); + sInstance.mSimName.clear(); + sInstance.mParseState = NOT_PARSED; + if (sim_string == sLocationStringHome) + { + gSavedSettings.setBOOL("LoginLastLocation", FALSE); + } + else if (sim_string == sLocationStringLast) + { + gSavedSettings.setBOOL("LoginLastLocation", TRUE); + } + else + { + char* curlstr = curl_unescape(sim_string.c_str(), sim_string.size()); + LLString tstring = LLString(curlstr); + curl_free(curlstr); + std::string::size_type idx = tstring.find("//"); + idx = (idx == LLString::npos) ? 0 : idx+2; + sInstance.mSimString = tstring.substr(idx); + } + LLPanelLogin::refreshLocation( false ); // in case LLPanelLogin is visible +} + +// "/100" -> 100 +// static +S32 LLURLSimString::parseGridIdx(const LLString& in_string, S32 idx0, S32* res, S32 max) +{ + if (idx0 == INT_MAX || in_string[idx0] != '/') + { + return INT_MAX; // parse error + } + idx0++; + LLString::size_type idx1 = in_string.find_first_of('/', idx0); + LLString::size_type len = (idx1 == LLString::npos) ? LLString::npos : idx1-idx0; + LLString tstring = in_string.substr(idx0,len); + if (!tstring.empty()) + { + S32 val = atoi(tstring.c_str()); + *res = llclamp(val,0,max); + } + return idx1; +} + +// "simname/x/y/z" -> mSimName = simname, mX = x, mY = y, mZ = z +// static +bool LLURLSimString::parse() +{ + if (sInstance.mParseState == NOT_SET) + { + return false; + } + if (sInstance.mParseState == NOT_PARSED) + { + if (parse(sInstance.mSimString, + &sInstance.mSimName, + &sInstance.mX, + &sInstance.mY, + &sInstance.mZ)) + { + sInstance.mParseState = PARSE_OK; + } + else + { + sInstance.mParseState = PARSE_FAIL; + } + } + return (sInstance.mParseState == PARSE_OK); +} + +// static +bool LLURLSimString::parse(const LLString& sim_string, std::string *region_name, S32 *x, S32 *y, S32 *z) +{ + // strip any bogus initial '/' + LLString::size_type idx0 = sim_string.find_first_not_of('/'); + if (idx0 == std::string::npos) idx0 = 0; + + LLString::size_type idx1 = sim_string.find_first_of('/', idx0); + LLString::size_type len = (idx1 == std::string::npos) ? std::string::npos : idx1-idx0; + LLString tstring = sim_string.substr(idx0,len); + *region_name = unescapeRegionName(tstring); + if (!region_name->empty()) + { + if (idx1 != std::string::npos) + { + idx1 = parseGridIdx(sim_string, idx1, x, 255); + idx1 = parseGridIdx(sim_string, idx1, y, 255); + idx1 = parseGridIdx(sim_string, idx1, z, 1000); + } + return true; + } + else + { + return false; + } +} + +// static +std::string LLURLSimString::getURL() +{ + std::string url; + if (sInstance.mParseState == PARSE_OK) + { + url = llformat("secondlife://%s/%d/%d/%d/", + sInstance.mSimName.c_str(), + sInstance.mX, + sInstance.mY, + sInstance.mZ); + } + return url; +} + +// static +std::string LLURLSimString::unescapeRegionName(std::string region_name) +{ + std::string result; + char* curlstr = curl_unescape(region_name.c_str(), region_name.size()); + result = std::string(curlstr); + curl_free(curlstr); + return result; +} diff --git a/linden/indra/newview/llurlsimstring.h b/linden/indra/newview/llurlsimstring.h new file mode 100644 index 0000000..701241e --- /dev/null +++ b/linden/indra/newview/llurlsimstring.h @@ -0,0 +1,81 @@ +/** + * @file llsimurlstring.h + * @brief Handles "SLURL fragments" like Ahern/123/45 for + * startup processing, login screen, prefs, etc. + * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * + * Copyright (c) 2006-2007, Linden Research, Inc. + * + * Second Life Viewer Source Code + * The source code in this file ("Source Code") is provided by Linden Lab + * to you under the terms of the GNU General Public License, version 2.0 + * ("GPL"), unless you have obtained a separate licensing agreement + * ("Other License"), formally executed by you and Linden Lab. Terms of + * the GPL can be found in doc/GPL-license.txt in this distribution, or + * online at http://secondlife.com/developers/opensource/gplv2 + * + * There are special exceptions to the terms and conditions of the GPL as + * it is applied to this Source Code. View the full text of the exception + * in the file doc/FLOSS-exception.txt in this software distribution, or + * online at http://secondlife.com/developers/opensource/flossexception + * + * By copying, modifying or distributing this software, you acknowledge + * that you have read and understood your obligations described above, + * and agree to abide by those obligations. + * + * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO + * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, + * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ + */ +#ifndef LLSIMURLSTRING_H +#define LLSIMURLSTRING_H + +#include "llstring.h" + +class LLURLSimString +{ +public: + enum { NOT_SET=0, NOT_PARSED=1, PARSE_OK=2, PARSE_FAIL=-1 }; + + static void setString(const LLString& url); + // Accepts all sorts of fragments: + // secondlife://RegionName/1/2/ + // sl://RegionName/1/2/3/ + // //Ahern/123/45/ + // Ahern + + static bool parse(); + // Returns true if we have an URL fragment in the static instance + // (and it parsed correctly, which is basically always because + // any bare region string is a valid fragment). + + static bool parse(const LLString& sim_string, std::string *region_name, S32 *x, S32 *y, S32 *z); + // Parse a sim string "Ahern/1/2" and return location data, + // doesn't affect static instance. + + static std::string getURL(); + // Get the canonical URL secondlife://RegionName/123/45/6/ + + static std::string unescapeRegionName(std::string region_name); + // Does URL unescaping, in particular %20 -> space + + LLURLSimString() : mX(128), mY(128), mZ(0), mParseState(NOT_PARSED) {} + +private: + static S32 parseGridIdx(const LLString& in_string, S32 idx0, S32* res, S32 max); + +public: + static LLURLSimString sInstance; + static LLString sLocationStringHome; + static LLString sLocationStringLast; + +public: + LLString mSimString; // "name/x/y/z" + LLString mSimName; + S32 mX,mY,mZ; + S32 mParseState; +}; + +#endif diff --git a/linden/indra/newview/llurlwhitelist.cpp b/linden/indra/newview/llurlwhitelist.cpp index e08ae42..6acd3c1 100644 --- a/linden/indra/newview/llurlwhitelist.cpp +++ b/linden/indra/newview/llurlwhitelist.cpp @@ -3,6 +3,8 @@ * @author Callum Prentice * @brief maintains a "white list" of acceptable URLS that are stored on disk * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llurlwhitelist.h b/linden/indra/newview/llurlwhitelist.h index a0c3dec..b9901b6 100644 --- a/linden/indra/newview/llurlwhitelist.h +++ b/linden/indra/newview/llurlwhitelist.h @@ -3,6 +3,8 @@ * @author Callum Prentice * @brief maintains a "white list" of acceptable URLS that are stored on disk * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLURLWHITELIST_H diff --git a/linden/indra/newview/lluserauth.cpp b/linden/indra/newview/lluserauth.cpp index 6c45b8d..196a4c8 100644 --- a/linden/indra/newview/lluserauth.cpp +++ b/linden/indra/newview/lluserauth.cpp @@ -2,6 +2,8 @@ * @file lluserauth.cpp * @brief LLUserAuth class implementation * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -145,10 +148,7 @@ void LLUserAuth::authenticate( } viewer_digest.toString(buffer); XMLRPC_VectorAppendString(params, "viewer_digest", buffer, 0); - if (last_exec_froze) - { - XMLRPC_VectorAppendString(params, "last_exec_froze", "true", 0); - } + XMLRPC_VectorAppendInt(params, "last_exec_event", (int) last_exec_froze); // append optional requests in an array XMLRPC_VALUE options = XMLRPC_CreateVector("options", xmlrpc_vector_array); diff --git a/linden/indra/newview/lluserauth.h b/linden/indra/newview/lluserauth.h index 22bcd48..d6ee1da 100644 --- a/linden/indra/newview/lluserauth.h +++ b/linden/indra/newview/lluserauth.h @@ -2,6 +2,8 @@ * @file lluserauth.h * @brief LLUserAuth class header file * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLUSERAUTH_H diff --git a/linden/indra/newview/llvelocitybar.cpp b/linden/indra/newview/llvelocitybar.cpp index c0c3a37..ceaad06 100644 --- a/linden/indra/newview/llvelocitybar.cpp +++ b/linden/indra/newview/llvelocitybar.cpp @@ -2,6 +2,8 @@ * @file llvelocitybar.cpp * @brief A user interface widget that displays user energy level * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llvelocitybar.h b/linden/indra/newview/llvelocitybar.h index c6b06ac..f811fde 100644 --- a/linden/indra/newview/llvelocitybar.h +++ b/linden/indra/newview/llvelocitybar.h @@ -2,6 +2,8 @@ * @file llvelocitybar.h * @brief A user interface widget that displays the user velocity * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVELOCITYBAR_H diff --git a/linden/indra/newview/llviewchildren.cpp b/linden/indra/newview/llviewchildren.cpp index 8c88757..a06d2fc 100644 --- a/linden/indra/newview/llviewchildren.cpp +++ b/linden/indra/newview/llviewchildren.cpp @@ -2,6 +2,8 @@ * @file llviewchildren.cpp * @brief LLViewChildren class implementation * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llviewchildren.h b/linden/indra/newview/llviewchildren.h index 16470dd..d3a09e9 100644 --- a/linden/indra/newview/llviewchildren.h +++ b/linden/indra/newview/llviewchildren.h @@ -2,6 +2,8 @@ * @file llviewchildren.h * @brief LLViewChildren class header file * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWCHILDREN_H diff --git a/linden/indra/newview/llviewerassetstorage.cpp b/linden/indra/newview/llviewerassetstorage.cpp index 7947700..1832c42 100644 --- a/linden/indra/newview/llviewerassetstorage.cpp +++ b/linden/indra/newview/llviewerassetstorage.cpp @@ -2,6 +2,8 @@ * @file llviewerassetstorage.cpp * @brief Subclass capable of loading asset data to/from an external source. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ diff --git a/linden/indra/newview/llviewerassetstorage.h b/linden/indra/newview/llviewerassetstorage.h index c49820a..39bab68 100644 --- a/linden/indra/newview/llviewerassetstorage.h +++ b/linden/indra/newview/llviewerassetstorage.h @@ -2,6 +2,8 @@ * @file llviewerassetstorage.h * @brief Class for loading asset data to/from an external source. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLVIEWERASSETSTORAGE_H diff --git a/linden/indra/newview/llviewerbuild.h b/linden/indra/newview/llviewerbuild.h index 82a35b0..dc7f46c 100644 --- a/linden/indra/newview/llviewerbuild.h +++ b/linden/indra/newview/llviewerbuild.h @@ -2,6 +2,8 @@ * @file llviewerbuild.h * @brief Sets viewer build number * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llversionviewer.h" diff --git a/linden/indra/newview/llviewercamera.cpp b/linden/indra/newview/llviewercamera.cpp index c52b51c..d4075b9 100644 --- a/linden/indra/newview/llviewercamera.cpp +++ b/linden/indra/newview/llviewercamera.cpp @@ -2,6 +2,8 @@ * @file llviewercamera.cpp * @brief LLViewerCamera class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include // for setprecision @@ -45,8 +48,6 @@ #include "llvovolume.h" #include "llworld.h" -BOOL LLViewerCamera::sDisableCameraConstraints = FALSE; - LLViewerCamera *gCamera = NULL; LLViewerCamera::LLViewerCamera() : LLCamera() diff --git a/linden/indra/newview/llviewercamera.h b/linden/indra/newview/llviewercamera.h index 6109711..a5b7b6f 100644 --- a/linden/indra/newview/llviewercamera.h +++ b/linden/indra/newview/llviewercamera.h @@ -2,6 +2,8 @@ * @file llviewercamera.h * @brief LLViewerCamera class header file * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERCAMERA_H @@ -103,7 +106,6 @@ protected: S16 mZoomSubregion; public: - static BOOL sDisableCameraConstraints; F64 mGLProjectionMatrix[16]; }; diff --git a/linden/indra/newview/llviewercontrol.cpp b/linden/indra/newview/llviewercontrol.cpp index 08abd2d..79ec70f 100644 --- a/linden/indra/newview/llviewercontrol.cpp +++ b/linden/indra/newview/llviewercontrol.cpp @@ -3,6 +3,8 @@ * @brief Viewer configuration * @author Richard Nelson * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -255,7 +258,7 @@ void LLFloaterSettingsDebug::updateControl(LLControlBase* controlp) color_swatch->setVisible(FALSE); childSetVisible("val_text", FALSE); childSetVisible("boolean_combo", FALSE); - mComment->setText(""); + mComment->setText(LLString::null); if (controlp) { @@ -291,7 +294,7 @@ void LLFloaterSettingsDebug::updateControl(LLControlBase* controlp) { case TYPE_U32: spinner1->setVisible(TRUE); - spinner1->setLabel("value"); + spinner1->setLabel(LLString("value")); // Debug, don't translate if (!spinner1->hasFocus()) { spinner1->setValue(sd); @@ -303,7 +306,7 @@ void LLFloaterSettingsDebug::updateControl(LLControlBase* controlp) break; case TYPE_S32: spinner1->setVisible(TRUE); - spinner1->setLabel("value"); + spinner1->setLabel(LLString("value")); // Debug, don't translate if (!spinner1->hasFocus()) { spinner1->setValue(sd); @@ -315,7 +318,7 @@ void LLFloaterSettingsDebug::updateControl(LLControlBase* controlp) break; case TYPE_F32: spinner1->setVisible(TRUE); - spinner1->setLabel("value"); + spinner1->setLabel(LLString("value")); // Debug, don't translate if (!spinner1->hasFocus()) { spinner1->setPrecision(3); @@ -349,11 +352,11 @@ void LLFloaterSettingsDebug::updateControl(LLControlBase* controlp) LLVector3 v; v.setValue(sd); spinner1->setVisible(TRUE); - spinner1->setLabel("X"); + spinner1->setLabel(LLString("X")); spinner2->setVisible(TRUE); - spinner2->setLabel("Y"); + spinner2->setLabel(LLString("Y")); spinner3->setVisible(TRUE); - spinner3->setLabel("Z"); + spinner3->setLabel(LLString("Z")); if (!spinner1->hasFocus()) { spinner1->setPrecision(3); @@ -376,11 +379,11 @@ void LLFloaterSettingsDebug::updateControl(LLControlBase* controlp) LLVector3d v; v.setValue(sd); spinner1->setVisible(TRUE); - spinner1->setLabel("X"); + spinner1->setLabel(LLString("X")); spinner2->setVisible(TRUE); - spinner2->setLabel("Y"); + spinner2->setLabel(LLString("Y")); spinner3->setVisible(TRUE); - spinner3->setLabel("Z"); + spinner3->setLabel(LLString("Z")); if (!spinner1->hasFocus()) { spinner1->setPrecision(3); @@ -403,13 +406,13 @@ void LLFloaterSettingsDebug::updateControl(LLControlBase* controlp) LLRect r; r.setValue(sd); spinner1->setVisible(TRUE); - spinner1->setLabel("Left"); + spinner1->setLabel(LLString("Left")); spinner2->setVisible(TRUE); - spinner2->setLabel("Right"); + spinner2->setLabel(LLString("Right")); spinner3->setVisible(TRUE); - spinner3->setLabel("Bottom"); + spinner3->setLabel(LLString("Bottom")); spinner4->setVisible(TRUE); - spinner4->setLabel("Top"); + spinner4->setLabel(LLString("Top")); if (!spinner1->hasFocus()) { spinner1->setPrecision(0); @@ -459,7 +462,7 @@ void LLFloaterSettingsDebug::updateControl(LLControlBase* controlp) color_swatch->set(LLColor4(sd), TRUE, FALSE); } spinner4->setVisible(TRUE); - spinner4->setLabel("Alpha"); + spinner4->setLabel(LLString("Alpha")); if (!spinner4->hasFocus()) { spinner4->setPrecision(3); @@ -487,7 +490,7 @@ void LLFloaterSettingsDebug::updateControl(LLControlBase* controlp) color_swatch->set(LLColor4(clr), TRUE, FALSE); } spinner4->setVisible(TRUE); - spinner4->setLabel("Alpha"); + spinner4->setLabel(LLString("Alpha")); if(!spinner4->hasFocus()) { spinner4->setPrecision(0); @@ -501,7 +504,7 @@ void LLFloaterSettingsDebug::updateControl(LLControlBase* controlp) break; } default: - mComment->setText("unknown"); + mComment->setText(LLString("unknown")); break; } } diff --git a/linden/indra/newview/llviewercontrol.h b/linden/indra/newview/llviewercontrol.h index 46363b1..3151261 100644 --- a/linden/indra/newview/llviewercontrol.h +++ b/linden/indra/newview/llviewercontrol.h @@ -2,6 +2,8 @@ * @file llviewercontrol.h * @brief references to viewer-specific control files * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERCONTROL_H diff --git a/linden/indra/newview/llviewerdisplay.cpp b/linden/indra/newview/llviewerdisplay.cpp index 64ad66c..b4dc093 100644 --- a/linden/indra/newview/llviewerdisplay.cpp +++ b/linden/indra/newview/llviewerdisplay.cpp @@ -2,6 +2,8 @@ * @file llviewerdisplay.cpp * @brief LLViewerDisplay class implementation * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -239,6 +242,10 @@ void display(BOOL rebuild, F32 zoom_factor, int subfield) LLVOAvatar::sRenderName = gSavedSettings.getS32("RenderName"); gPipeline.mBackfaceCull = TRUE; gFrameCount++; + if (gFocusMgr.getAppHasFocus()) + { + gForegroundFrameCount++; + } ////////////////////////////////////////////////////////// // diff --git a/linden/indra/newview/llviewerdisplay.h b/linden/indra/newview/llviewerdisplay.h index 9145a2d..b42c6e9 100644 --- a/linden/indra/newview/llviewerdisplay.h +++ b/linden/indra/newview/llviewerdisplay.h @@ -2,6 +2,8 @@ * @file llviewerdisplay.h * @brief LLViewerDisplay class header file * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERDISPLAY_H diff --git a/linden/indra/newview/llviewergenericmessage.cpp b/linden/indra/newview/llviewergenericmessage.cpp index 0e1ce49..81b7594 100644 --- a/linden/indra/newview/llviewergenericmessage.cpp +++ b/linden/indra/newview/llviewergenericmessage.cpp @@ -3,7 +3,9 @@ * @brief Handle processing of "generic messages" which contain short lists of strings. * @author James Cook * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llviewergenericmessage.h b/linden/indra/newview/llviewergenericmessage.h index b0d02a2..2e12f54 100644 --- a/linden/indra/newview/llviewergenericmessage.h +++ b/linden/indra/newview/llviewergenericmessage.h @@ -3,7 +3,9 @@ * @brief Handle processing of "generic messages" which contain short lists of strings. * @author James Cook * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLVIEWERGENERICMESSAGE_H diff --git a/linden/indra/newview/llviewergesture.cpp b/linden/indra/newview/llviewergesture.cpp index de8a098..4434098 100644 --- a/linden/indra/newview/llviewergesture.cpp +++ b/linden/indra/newview/llviewergesture.cpp @@ -2,6 +2,8 @@ * @file llviewergesture.cpp * @brief LLViewerGesture class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llviewergesture.h b/linden/indra/newview/llviewergesture.h index 5f6b795..cc707e9 100644 --- a/linden/indra/newview/llviewergesture.h +++ b/linden/indra/newview/llviewergesture.h @@ -2,6 +2,8 @@ * @file llviewergesture.h * @brief LLViewerGesture class header file * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERGESTURE_H diff --git a/linden/indra/newview/llviewerimage.cpp b/linden/indra/newview/llviewerimage.cpp index f4cd582..240ffa5 100644 --- a/linden/indra/newview/llviewerimage.cpp +++ b/linden/indra/newview/llviewerimage.cpp @@ -2,6 +2,8 @@ * @file llviewerimage.cpp * @brief Object which handles a received image (and associated texture(s)) * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llviewerimage.h b/linden/indra/newview/llviewerimage.h index 9e7689f..385823c 100644 --- a/linden/indra/newview/llviewerimage.h +++ b/linden/indra/newview/llviewerimage.h @@ -2,6 +2,8 @@ * @file llviewerimage.h * @brief Object for managing images and their textures * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERIMAGE_H diff --git a/linden/indra/newview/llviewerimagelist.cpp b/linden/indra/newview/llviewerimagelist.cpp index 890629e..aa9c2c0 100644 --- a/linden/indra/newview/llviewerimagelist.cpp +++ b/linden/indra/newview/llviewerimagelist.cpp @@ -2,6 +2,8 @@ * @file llviewerimagelist.cpp * @brief Object for managing the list of images within a region * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -111,8 +114,6 @@ void LLViewerImageList::init() mMovieImageHasMips = FALSE; doPreloadImages(); - - decodeAllImages(5.f); // decode preloaded images } void LLViewerImageList::doPreloadImages() @@ -123,19 +124,14 @@ void LLViewerImageList::doPreloadImages() LLViewerImage::sMissingAssetImagep = preloadImage("missing_asset.tga" , LLUUID::null, TRUE); // Set the "white" image - LLViewerImage::sWhiteImagep = preloadImage("white.tga", LLUUID::null, TRUE);; + LLViewerImage::sWhiteImagep = preloadImage("white.tga", LLUUID::null, TRUE); // Speeds up startup by 4-5 seconds. JC if (!gPreloadImages) return; - // Preload some images - preloadImage("active_voice_tab.tga", LLUUID::null, FALSE); - preloadImage("button_anim_pause.tga", LLUUID::null, FALSE); - preloadImage("button_anim_pause_selected.tga", LLUUID::null, FALSE); - preloadImage("button_anim_play.tga", LLUUID::null, FALSE); - preloadImage("button_anim_play_selected.tga", LLUUID::null, FALSE); - preloadImage("button_anim_stop.tga", LLUUID::null, FALSE); - preloadImage("button_anim_stop_selected.tga", LLUUID::null, FALSE); + // Images listed here are immediately decoded, before the login screen. + // Since this slows down perceived viewer startup time, only include + // images here for buttons/checkboxes/etc. that are immediately visible. preloadImage("button_disabled_32x128.tga", LLUUID::null, FALSE); preloadImage("button_enabled_32x128.tga", LLUUID::null, FALSE); preloadImage("button_enabled_selected_32x128.tga", LLUUID::null, FALSE); @@ -145,6 +141,48 @@ void LLViewerImageList::doPreloadImages() preloadImage("checkbox_enabled_true.tga", LLUUID::null, FALSE); preloadImage("close_in_blue.tga", LLUUID::null, FALSE); preloadImage("combobox_arrow.tga", LLUUID::null, FALSE); + preloadImage("minimize.tga", LLUUID::null, FALSE); + preloadImage("minimize_pressed.tga", LLUUID::null, FALSE); + preloadImage("radio_active_false.tga", LLUUID::null, FALSE); + preloadImage("radio_active_true.tga", LLUUID::null, FALSE); + preloadImage("radio_inactive_false.tga", LLUUID::null, FALSE); + preloadImage("radio_inactive_true.tga", LLUUID::null, FALSE); + preloadImage("resize_handle_bottom_right_blue.tga", LLUUID::null, FALSE); + preloadImage("rounded_square.tga", LLUUID::null, FALSE); + preloadImage("rounded_square_soft.tga", LLUUID::null, FALSE); + preloadImage("scrollbutton_down_in_blue.tga", LLUUID::null, FALSE); + preloadImage("scrollbutton_down_out_blue.tga", LLUUID::null, FALSE); + preloadImage("scrollbutton_left_in_blue.tga", LLUUID::null, FALSE); + preloadImage("scrollbutton_left_out_blue.tga", LLUUID::null, FALSE); + preloadImage("scrollbutton_right_in_blue.tga", LLUUID::null, FALSE); + preloadImage("scrollbutton_right_out_blue.tga", LLUUID::null, FALSE); + preloadImage("scrollbutton_up_in_blue.tga", LLUUID::null, FALSE); + preloadImage("scrollbutton_up_out_blue.tga", LLUUID::null, FALSE); + preloadImage("spin_down_in_blue.tga", LLUUID::null, FALSE); + preloadImage("spin_down_out_blue.tga", LLUUID::null, FALSE); + preloadImage("spin_up_in_blue.tga", LLUUID::null, FALSE); + preloadImage("spin_up_out_blue.tga", LLUUID::null, FALSE); + preloadImage("square_btn_32x128.tga", LLUUID::null, FALSE); + preloadImage("square_btn_selected_32x128.tga", LLUUID::null, FALSE); + preloadImage("startup_logo.tga", LLUUID::null, FALSE); // <<<<<<< --- needed? + preloadImage("tab_bottom_blue.tga", LLUUID::null, FALSE); + preloadImage("tab_bottom_selected_blue.tga", LLUUID::null, FALSE); + preloadImage("tab_left.tga", LLUUID::null, FALSE); + preloadImage("tab_left_selected.tga", LLUUID::null, FALSE); + preloadImage("tab_top_blue.tga", LLUUID::null, FALSE); + preloadImage("tab_top_selected_blue.tga", LLUUID::null, FALSE); + + decodeAllImages(2.f); // decode preloaded images + + // These images are queued for decode during the login sequence, when + // we have a progress bar. + preloadImage("active_voice_tab.tga", LLUUID::null, FALSE); + preloadImage("button_anim_pause.tga", LLUUID::null, FALSE); + preloadImage("button_anim_pause_selected.tga", LLUUID::null, FALSE); + preloadImage("button_anim_play.tga", LLUUID::null, FALSE); + preloadImage("button_anim_play_selected.tga", LLUUID::null, FALSE); + preloadImage("button_anim_stop.tga", LLUUID::null, FALSE); + preloadImage("button_anim_stop_selected.tga", LLUUID::null, FALSE); preloadImage("crosshairs.tga", LLUUID::null, FALSE); preloadImage("direction_arrow.tga", LLUUID::null, FALSE); preloadImage("eyes.tga", LLUUID::null, TRUE); @@ -196,9 +234,14 @@ void LLViewerImageList::doPreloadImages() preloadImage("inv_item_texture.tga", LLUUID::null, FALSE); preloadImage("inv_item_underpants.tga", LLUUID::null, FALSE); preloadImage("inv_item_undershirt.tga", LLUUID::null, FALSE); + preloadImage("lag_status_critical.tga", LLUUID::null, FALSE); + preloadImage("lag_status_good.tga", LLUUID::null, FALSE); + preloadImage("lag_status_warning.tga", LLUUID::null, FALSE); preloadImage("legend.tga", LLUUID::null, FALSE); preloadImage("map_avatar_16.tga", LLUUID::null, FALSE); preloadImage("map_avatar_8.tga", LLUUID::null, FALSE); + preloadImage("map_avatar_above_8.tga", LLUUID::null, FALSE); + preloadImage("map_avatar_below_8.tga", LLUUID::null, FALSE); preloadImage("map_avatar_you_8.tga", LLUUID::null, FALSE); preloadImage("map_event.tga", LLUUID::null, FALSE); preloadImage("map_event_mature.tga", LLUUID::null, FALSE); @@ -207,8 +250,6 @@ void LLViewerImageList::doPreloadImages() preloadImage("map_telehub.tga", LLUUID::null, FALSE); preloadImage("map_track_16.tga", LLUUID::null, FALSE); preloadImage("media_icon.tga", LLUUID::null, FALSE); - preloadImage("minimize.tga", LLUUID::null, FALSE); - preloadImage("minimize_pressed.tga", LLUUID::null, FALSE); preloadImage("music_icon.tga", LLUUID::null, FALSE); preloadImage("noentrylines.tga", LLUUID::null, TRUE); preloadImage("noentrypasslines.tga", LLUUID::null, TRUE); @@ -245,31 +286,9 @@ void LLViewerImageList::doPreloadImages() preloadImage("object_tree_active.tga", LLUUID::null, FALSE); preloadImage("object_tube.tga", LLUUID::null, FALSE); preloadImage("object_tube_active.tga", LLUUID::null, FALSE); - preloadImage("pixiesmall.tga", LLUUID::null, TRUE); - preloadImage("radio_active_false.tga", LLUUID::null, FALSE); - preloadImage("radio_active_true.tga", LLUUID::null, FALSE); - preloadImage("radio_inactive_false.tga", LLUUID::null, FALSE); - preloadImage("radio_inactive_true.tga", LLUUID::null, FALSE); - preloadImage("resize_handle_bottom_right_blue.tga", LLUUID::null, FALSE); - preloadImage("rounded_square.tga", LLUUID::null, FALSE); - preloadImage("rounded_square_soft.tga", LLUUID::null, FALSE); + preloadImage("pixiesmall.tga", LLUUID::null, TRUE); // particle systems preloadImage("script_error.tga", LLUUID::null, TRUE); - preloadImage("scrollbutton_down_in_blue.tga", LLUUID::null, FALSE); - preloadImage("scrollbutton_down_out_blue.tga", LLUUID::null, FALSE); - preloadImage("scrollbutton_left_in_blue.tga", LLUUID::null, FALSE); - preloadImage("scrollbutton_left_out_blue.tga", LLUUID::null, FALSE); - preloadImage("scrollbutton_right_in_blue.tga", LLUUID::null, FALSE); - preloadImage("scrollbutton_right_out_blue.tga", LLUUID::null, FALSE); - preloadImage("scrollbutton_up_in_blue.tga", LLUUID::null, FALSE); - preloadImage("scrollbutton_up_out_blue.tga", LLUUID::null, FALSE); preloadImage("silhouette.tga", LLUUID::null, TRUE); - preloadImage("spin_down_in_blue.tga", LLUUID::null, FALSE); - preloadImage("spin_down_out_blue.tga", LLUUID::null, FALSE); - preloadImage("spin_up_in_blue.tga", LLUUID::null, FALSE); - preloadImage("spin_up_out_blue.tga", LLUUID::null, FALSE); - preloadImage("square_btn_32x128.tga", LLUUID::null, FALSE); - preloadImage("square_btn_selected_32x128.tga", LLUUID::null, FALSE); - preloadImage("startup_logo.tga", LLUUID::null, FALSE); preloadImage("status_build.tga", LLUUID::null, FALSE); preloadImage("status_buy_currency.tga", LLUUID::null, FALSE); preloadImage("status_buy_currency_pressed.tga", LLUUID::null, FALSE); @@ -278,18 +297,11 @@ void LLViewerImageList::doPreloadImages() preloadImage("status_fly.tga", LLUUID::null, FALSE); preloadImage("status_health.tga", LLUUID::null, FALSE); preloadImage("status_scripts.tga", LLUUID::null, FALSE); - preloadImage("tab_bottom_blue.tga", LLUUID::null, FALSE); - preloadImage("tab_bottom_selected_blue.tga", LLUUID::null, FALSE); - preloadImage("tab_left.tga", LLUUID::null, FALSE); - preloadImage("tab_left_selected.tga", LLUUID::null, FALSE); - preloadImage("tab_top_blue.tga", LLUUID::null, FALSE); - preloadImage("tab_top_selected_blue.tga", LLUUID::null, FALSE); preloadImage("tool_dozer.tga", LLUUID::null, FALSE); preloadImage("tool_dozer_active.tga", LLUUID::null, FALSE); preloadImage("tool_zoom.tga", LLUUID::null, FALSE); preloadImage("tool_zoom_active.tga", LLUUID::null, FALSE); preloadImage("volume_icon.tga", LLUUID::null, FALSE); - preloadImage("white.tga", LLUUID::null, TRUE); preloadImage("icn_active-speakers-dot-lvl0.tga", LLUUID::null, FALSE); preloadImage("icn_active-speakers-dot-lvl1.tga", LLUUID::null, FALSE); preloadImage("icn_active-speakers-dot-lvl2.tga", LLUUID::null, FALSE); @@ -977,63 +989,64 @@ void LLViewerImageList::updateImagesUpdateStats() void LLViewerImageList::decodeAllImages(F32 max_time) { LLTimer timer; - if(!gNoRender) + if(gNoRender) return; + + // Update texture stats and priorities + std::vector > image_list; + for (image_priority_list_t::iterator iter = mImageList.begin(); + iter != mImageList.end(); ) { - // Update texture stats and priorities - std::vector > image_list; - for (image_priority_list_t::iterator iter = mImageList.begin(); - iter != mImageList.end(); ) - { - LLViewerImage* imagep = *iter++; - image_list.push_back(imagep); - imagep->mInImageList = FALSE; - } - mImageList.clear(); - for (std::vector >::iterator iter = image_list.begin(); - iter != image_list.end(); ++iter) - { - LLViewerImage* imagep = *iter; - imagep->processTextureStats(); - F32 decode_priority = imagep->calcDecodePriority(); - imagep->setDecodePriority(decode_priority); - mImageList.insert(imagep); - imagep->mInImageList = TRUE; - } - image_list.clear(); - - // Update fetch (decode) - for (image_priority_list_t::iterator iter = mImageList.begin(); - iter != mImageList.end(); ) - { - LLViewerImage* imagep = *iter++; - imagep->updateFetch(); - } - // Run threads - while (1) - { - gTextureCache->update(1); // unpauses the texture cache thread - gImageDecodeThread->update(1); // unpauses the image thread - S32 fetch_pending = gTextureFetch->update(1); // unpauses the texture fetch thread - if (fetch_pending == 0 || timer.getElapsedTimeF32() > max_time) - { - break; - } - } - // Update fetch again - for (image_priority_list_t::iterator iter = mImageList.begin(); - iter != mImageList.end(); ) + LLViewerImage* imagep = *iter++; + image_list.push_back(imagep); + imagep->mInImageList = FALSE; + } + mImageList.clear(); + for (std::vector >::iterator iter = image_list.begin(); + iter != image_list.end(); ++iter) + { + LLViewerImage* imagep = *iter; + imagep->processTextureStats(); + F32 decode_priority = imagep->calcDecodePriority(); + imagep->setDecodePriority(decode_priority); + mImageList.insert(imagep); + imagep->mInImageList = TRUE; + } + image_list.clear(); + + // Update fetch (decode) + for (image_priority_list_t::iterator iter = mImageList.begin(); + iter != mImageList.end(); ) + { + LLViewerImage* imagep = *iter++; + imagep->updateFetch(); + } + // Run threads + S32 fetch_pending = 0; + while (1) + { + gTextureCache->update(1); // unpauses the texture cache thread + gImageDecodeThread->update(1); // unpauses the image thread + fetch_pending = gTextureFetch->update(1); // unpauses the texture fetch thread + if (fetch_pending == 0 || timer.getElapsedTimeF32() > max_time) { - LLViewerImage* imagep = *iter++; - imagep->updateFetch(); + break; } - max_time -= timer.getElapsedTimeF32(); - max_time = llmax(max_time, .01f); - updateImagesCreateTextures(max_time); } - if (timer.getElapsedTimeF32() > .5f) // seconds + // Update fetch again + for (image_priority_list_t::iterator iter = mImageList.begin(); + iter != mImageList.end(); ) { - llinfos << "decodeAllImages() took " << timer.getElapsedTimeF32() << " seconds. " << llendl; + LLViewerImage* imagep = *iter++; + imagep->updateFetch(); } + max_time -= timer.getElapsedTimeF32(); + max_time = llmax(max_time, .01f); + F32 create_time = updateImagesCreateTextures(max_time); + + llinfos << "decodeAllImages() took " << timer.getElapsedTimeF32() << " seconds. " + << " fetch_pending " << fetch_pending + << " create_time " << create_time + << llendl; } diff --git a/linden/indra/newview/llviewerimagelist.h b/linden/indra/newview/llviewerimagelist.h index 266bcfc..d587e61 100644 --- a/linden/indra/newview/llviewerimagelist.h +++ b/linden/indra/newview/llviewerimagelist.h @@ -2,6 +2,8 @@ * @file llviewerimagelist.h * @brief Object for managing the list of images within a region * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERIMAGELIST_H diff --git a/linden/indra/newview/llviewerinventory.cpp b/linden/indra/newview/llviewerinventory.cpp index c9cd52f..b436465 100644 --- a/linden/indra/newview/llviewerinventory.cpp +++ b/linden/indra/newview/llviewerinventory.cpp @@ -2,6 +2,8 @@ * @file llviewerinventory.cpp * @brief Implementation of the viewer side inventory objects. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llviewerinventory.h b/linden/indra/newview/llviewerinventory.h index 1226a83..2aba7f4 100644 --- a/linden/indra/newview/llviewerinventory.h +++ b/linden/indra/newview/llviewerinventory.h @@ -2,6 +2,8 @@ * @file llviewerinventory.h * @brief Declaration of the inventory bits that only used on the viewer. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERINVENTORY_H diff --git a/linden/indra/newview/llviewerjoint.cpp b/linden/indra/newview/llviewerjoint.cpp index ca624bd..093aca6 100644 --- a/linden/indra/newview/llviewerjoint.cpp +++ b/linden/indra/newview/llviewerjoint.cpp @@ -2,6 +2,8 @@ * @file llviewerjoint.cpp * @brief Implementation of LLViewerJoint class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- diff --git a/linden/indra/newview/llviewerjoint.h b/linden/indra/newview/llviewerjoint.h index 8d28a03..e432258 100644 --- a/linden/indra/newview/llviewerjoint.h +++ b/linden/indra/newview/llviewerjoint.h @@ -2,6 +2,8 @@ * @file llviewerjoint.h * @brief Implementation of LLViewerJoint class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERJOINT_H diff --git a/linden/indra/newview/llviewerjointattachment.cpp b/linden/indra/newview/llviewerjointattachment.cpp index f75ac48..186b141 100644 --- a/linden/indra/newview/llviewerjointattachment.cpp +++ b/linden/indra/newview/llviewerjointattachment.cpp @@ -2,6 +2,8 @@ * @file llviewerjointattachment.cpp * @brief Implementation of LLViewerJointAttachment class * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llviewerjointattachment.h b/linden/indra/newview/llviewerjointattachment.h index ce2f8b9..a834e68 100644 --- a/linden/indra/newview/llviewerjointattachment.h +++ b/linden/indra/newview/llviewerjointattachment.h @@ -2,6 +2,8 @@ * @file llviewerjointattachment.h * @brief Implementation of LLViewerJointAttachment class * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERJOINTATTACHMENT_H diff --git a/linden/indra/newview/llviewerjointmesh.cpp b/linden/indra/newview/llviewerjointmesh.cpp index 09fd015..dfd9ec1 100644 --- a/linden/indra/newview/llviewerjointmesh.cpp +++ b/linden/indra/newview/llviewerjointmesh.cpp @@ -2,6 +2,8 @@ * @file llviewerjointmesh.cpp * @brief Implementation of LLViewerJointMesh class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- diff --git a/linden/indra/newview/llviewerjointmesh.h b/linden/indra/newview/llviewerjointmesh.h index b40daed..8a3cc1a 100644 --- a/linden/indra/newview/llviewerjointmesh.h +++ b/linden/indra/newview/llviewerjointmesh.h @@ -2,6 +2,8 @@ * @file llviewerjointmesh.h * @brief Implementation of LLViewerJointMesh class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERJOINTMESH_H diff --git a/linden/indra/newview/llviewerjointmesh_sse.cpp b/linden/indra/newview/llviewerjointmesh_sse.cpp index 95d621a..7a0d475 100644 --- a/linden/indra/newview/llviewerjointmesh_sse.cpp +++ b/linden/indra/newview/llviewerjointmesh_sse.cpp @@ -5,7 +5,9 @@ * * *NOTE: Disabled on Windows builds. See llv4math.h for details. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -27,6 +29,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- diff --git a/linden/indra/newview/llviewerjointmesh_sse2.cpp b/linden/indra/newview/llviewerjointmesh_sse2.cpp index 27aab80..129f06c 100644 --- a/linden/indra/newview/llviewerjointmesh_sse2.cpp +++ b/linden/indra/newview/llviewerjointmesh_sse2.cpp @@ -5,7 +5,9 @@ * * *NOTE: Disabled on Windows builds. See llv4math.h for details. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -27,6 +29,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Visual Studio required settings for this file: diff --git a/linden/indra/newview/llviewerjointmesh_vec.cpp b/linden/indra/newview/llviewerjointmesh_vec.cpp index 39c50de..c7be7ce 100644 --- a/linden/indra/newview/llviewerjointmesh_vec.cpp +++ b/linden/indra/newview/llviewerjointmesh_vec.cpp @@ -5,7 +5,9 @@ * * *NOTE: See llv4math.h for notes on SSE/Altivec vector code. * - * Copyright (c) 2007-2007, Linden Research, Inc. + * $LicenseInfo:firstyear=2007&license=viewergpl$ + * + * Copyright (c) 2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab @@ -27,6 +29,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- diff --git a/linden/indra/newview/llviewerjointshape.cpp b/linden/indra/newview/llviewerjointshape.cpp index 478c041..a79d8a2 100644 --- a/linden/indra/newview/llviewerjointshape.cpp +++ b/linden/indra/newview/llviewerjointshape.cpp @@ -2,6 +2,8 @@ * @file llviewerjointshape.cpp * @brief Implementation of LLViewerJointShape class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- diff --git a/linden/indra/newview/llviewerjointshape.h b/linden/indra/newview/llviewerjointshape.h index 68f08ec..22b3898 100644 --- a/linden/indra/newview/llviewerjointshape.h +++ b/linden/indra/newview/llviewerjointshape.h @@ -2,6 +2,8 @@ * @file llviewerjointshape.h * @brief Implementation of LLViewerJointShape class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERJOINTSHAPE_H diff --git a/linden/indra/newview/llviewerjoystick.cpp b/linden/indra/newview/llviewerjoystick.cpp index bef769e..c3c504f 100644 --- a/linden/indra/newview/llviewerjoystick.cpp +++ b/linden/indra/newview/llviewerjoystick.cpp @@ -2,6 +2,8 @@ * @file llviewerjoystick.cpp * @brief Joystick functionality. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llviewerjoystick.h b/linden/indra/newview/llviewerjoystick.h index ee6036f..f2fc24b 100644 --- a/linden/indra/newview/llviewerjoystick.h +++ b/linden/indra/newview/llviewerjoystick.h @@ -2,6 +2,8 @@ * @file llviewerjoystick.h * @brief Viewer joystick functionality. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERJOYSTICK_H diff --git a/linden/indra/newview/llviewerkeyboard.cpp b/linden/indra/newview/llviewerkeyboard.cpp index ad931cd..b5d30df 100644 --- a/linden/indra/newview/llviewerkeyboard.cpp +++ b/linden/indra/newview/llviewerkeyboard.cpp @@ -2,6 +2,8 @@ * @file llviewerkeyboard.cpp * @brief LLViewerKeyboard class implementation * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llviewerkeyboard.h b/linden/indra/newview/llviewerkeyboard.h index 7bcb591..350d6d8 100644 --- a/linden/indra/newview/llviewerkeyboard.h +++ b/linden/indra/newview/llviewerkeyboard.h @@ -2,6 +2,8 @@ * @file llviewerkeyboard.h * @brief LLViewerKeyboard class header file * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERKEYBOARD_H diff --git a/linden/indra/newview/llviewerlayer.cpp b/linden/indra/newview/llviewerlayer.cpp index 2e50a05..89e8289 100644 --- a/linden/indra/newview/llviewerlayer.cpp +++ b/linden/indra/newview/llviewerlayer.cpp @@ -2,6 +2,8 @@ * @file llviewerlayer.cpp * @brief LLViewerLayer class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llviewerlayer.h b/linden/indra/newview/llviewerlayer.h index ad3a9ef..d67ceed 100644 --- a/linden/indra/newview/llviewerlayer.h +++ b/linden/indra/newview/llviewerlayer.h @@ -2,6 +2,8 @@ * @file llviewerlayer.h * @brief LLViewerLayer class header file * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERLAYER_H diff --git a/linden/indra/newview/llviewermenu.cpp b/linden/indra/newview/llviewermenu.cpp index 0d7a2cd..28c5049 100644 --- a/linden/indra/newview/llviewermenu.cpp +++ b/linden/indra/newview/llviewermenu.cpp @@ -2,6 +2,8 @@ * @file llviewermenu.cpp * @brief Builds menus out of items. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -103,8 +106,8 @@ #include "llfloatergroups.h" #include "llfloaterhtml.h" #include "llfloaterhtmlhelp.h" -#include "llfloaterhtmlfind.h" #include "llfloaterinspect.h" +#include "llfloaterlagmeter.h" #include "llfloaterland.h" #include "llfloaterlandholdings.h" #include "llfloatermap.h" @@ -359,6 +362,7 @@ void toggle_show_xui_names(void *); BOOL check_show_xui_names(void *); // Debug UI +void handle_slurl_test(void*); void handle_save_to_xml(void*); void handle_load_from_xml(void*); @@ -632,10 +636,12 @@ void init_menus() // flash when an item is triggered (the flash occurs in the holder) gViewerWindow->getRootView()->addChild(gMenuHolder); - gMenuHolder->childSetLabelArg("Upload Image", "[COST]", "10"); - gMenuHolder->childSetLabelArg("Upload Sound", "[COST]", "10"); - gMenuHolder->childSetLabelArg("Upload Animation", "[COST]", "10"); - gMenuHolder->childSetLabelArg("Bulk Upload", "[COST]", "10"); + // *TODO:Get the cost info from the server + const LLString upload_cost("10"); + gMenuHolder->childSetLabelArg("Upload Image", "[COST]", upload_cost); + gMenuHolder->childSetLabelArg("Upload Sound", "[COST]", upload_cost); + gMenuHolder->childSetLabelArg("Upload Animation", "[COST]", upload_cost); + gMenuHolder->childSetLabelArg("Bulk Upload", "[COST]", upload_cost); gAFKMenu = (LLMenuItemCallGL*)gMenuBarView->getChildByName("Set Away", TRUE); gBusyMenu = (LLMenuItemCallGL*)gMenuBarView->getChildByName("Set Busy", TRUE); @@ -768,9 +774,12 @@ void init_client_menu(LLMenuGL* menu) NULL, &menu_check_control, (void*)"HighResSnapshot")); - - menu->append(new LLMenuItemToggleGL("Quiet Snapshots to Disk", - &gQuietSnapshot)); + + menu->append(new LLMenuItemCheckGL( "Quiet Snapshots to Disk", + &menu_toggle_control, + NULL, + &menu_check_control, + (void*)"QuietSnapshotsToDisk")); menu->append(new LLMenuItemCheckGL( "Compress Snapshots to Disk", &menu_toggle_control, @@ -897,8 +906,11 @@ void init_client_menu(LLMenuGL* menu) &menu_check_control, (void*)"LimitSelectDistance")); - menu->append(new LLMenuItemToggleGL("Disable Camera Constraints", - &LLViewerCamera::sDisableCameraConstraints, 'C', MASK_ALT | MASK_CONTROL )); + menu->append(new LLMenuItemCheckGL("Disable Camera Constraints", + &menu_toggle_control, + NULL, + &menu_check_control, + (void*)"DisableCameraConstraints")); menu->append(new LLMenuItemCheckGL("Joystick Flycam", &handle_toggle_flycam,NULL,&check_flycam,NULL)); @@ -989,6 +1001,7 @@ extern BOOL gVectorizePerfTest; void init_debug_ui_menu(LLMenuGL* menu) { + menu->append(new LLMenuItemCallGL("SLURL Test", &handle_slurl_test)); menu->append(new LLMenuItemCallGL("Editable UI", &edit_ui)); menu->append(new LLMenuItemToggleGL("Async Keystrokes", &gHandleKeysAsync)); menu->append(new LLMenuItemCallGL( "Dump SelectMgr", &dump_select_mgr)); @@ -3384,31 +3397,33 @@ void derez_objects(EDeRezDestination dest, const LLUUID& dest_id) } //gInventoryView->setPanelOpen(TRUE); - LLObjectSelectionHandle selection = gSelectMgr->getSelection(); - LLViewerObject* object = NULL; - LLSelectNode* node = selection->getFirstRootNode(); - if(!node) return; - object = node->getObject(); - if(!object) return; - LLViewerRegion* region = object->getRegion(); - char* error = NULL; - + std::string error; + LLDynamicArray derez_objects; + // Check conditions that we can't deal with, building a list of // everything that we'll actually be derezzing. - LLDynamicArray derez_objects; - BOOL can_derez_current; - for( ; node != NULL; node = selection->getNextRootNode()) + LLViewerRegion* first_region = NULL; + for (LLObjectSelection::valid_root_iterator iter = gSelectMgr->getSelection()->valid_root_begin(); + iter != gSelectMgr->getSelection()->valid_root_end(); iter++) { - object = node->getObject(); - if(!object || !node->mValid) continue; - if(object->getRegion() != region) + LLSelectNode* node = *iter; + LLViewerObject* object = node->getObject(); + LLViewerRegion* region = object->getRegion(); + if (!first_region) { - // Derez doesn't work at all if the some of the objects - // are in regions besides the first object selected. - - // ...crosses region boundaries - error = "AcquireErrorObjectSpan"; - break; + first_region = region; + } + else + { + if(region != first_region) + { + // Derez doesn't work at all if the some of the objects + // are in regions besides the first object selected. + + // ...crosses region boundaries + error = "AcquireErrorObjectSpan"; + break; + } } if (object->isAvatar()) { @@ -3429,7 +3444,7 @@ void derez_objects(EDeRezDestination dest, const LLUUID& dest_id) */ continue; } - can_derez_current = FALSE; + BOOL can_derez_current = FALSE; switch(dest) { case DRD_TAKE_INTO_AGENT_INVENTORY: @@ -3473,7 +3488,7 @@ void derez_objects(EDeRezDestination dest, const LLUUID& dest_id) error = "AcquireErrorTooManyObjects"; } - if(!error && derez_objects.count() > 0) + if(error.empty() && derez_objects.count() > 0) { U8 d = (U8)dest; LLUUID tid; @@ -3502,7 +3517,7 @@ void derez_objects(EDeRezDestination dest, const LLUUID& dest_id) && (objects_in_packet++ < MAX_ROOTS_PER_PACKET)) { - object = derez_objects.get(object_index++); + LLViewerObject* object = derez_objects.get(object_index++); msg->nextBlockFast(_PREHASH_ObjectData); msg->addU32Fast(_PREHASH_ObjectLocalID, object->getLocalID()); // VEFFECT: DerezObject @@ -3510,7 +3525,7 @@ void derez_objects(EDeRezDestination dest, const LLUUID& dest_id) effectp->setPositionGlobal(object->getPositionGlobal()); effectp->setColor(LLColor4U(gAgent.getEffectColor())); } - msg->sendReliable(region->getHost()); + msg->sendReliable(first_region->getHost()); } make_ui_sound("UISndObjectRezOut"); @@ -3521,7 +3536,7 @@ void derez_objects(EDeRezDestination dest, const LLUUID& dest_id) gViewerWindow->getWindow()->incBusyCount(); } } - else if(error) + else if(!error.empty()) { gViewerWindow->alertXml(error); } @@ -3601,20 +3616,17 @@ class LLObjectEnableReturn : public view_listener_t } else { - LLObjectSelectionHandle selection = gSelectMgr->getSelection(); - LLViewerObject* obj = NULL; - for(obj = selection->getFirstRootObject(); - obj; - obj = selection->getNextRootObject()) + struct f : public LLSelectedObjectFunctor { - if (obj->isOverAgentOwnedLand() - || obj->isOverGroupOwnedLand() - || obj->permModify()) + virtual bool apply(LLViewerObject* obj) { - new_value = true; - break; + return (obj->isOverAgentOwnedLand() || + obj->isOverGroupOwnedLand() || + obj->permModify()); } - } + } func; + const bool firstonly = true; + new_value = gSelectMgr->getSelection()->applyToRootObjects(&func, firstonly); } } } @@ -3630,373 +3642,25 @@ void force_take_copy(void*) const LLUUID& category_id = gInventory.findCategoryUUIDForType(LLAssetType::AT_OBJECT); derez_objects(DRD_FORCE_TO_GOD_INVENTORY, category_id); } -#ifdef _CORY_TESTING - -void force_export_copy(void*) -{ - LLViewerObject* object = NULL; - LLSelectNode* node = gSelectMgr->getSelection()->getFirstNode(); - if(!node) return; - object = node->getObject(); - if(!object) return; - - - LLString proposed_name; - proposed_name.append(node->mName); - proposed_name.append( ".slg" ); - - LLViewerRegion* region = object->getRegion(); - - // Check conditions that we can't deal with, building a list of - // everything that we'll actually be derezzing. - - std::vector export_objects; - std::vector export_names; - std::vector export_descriptions; - - S32 object_index = 0; - - for( ; node != NULL; node = gSelectMgr->getSelection()->getNextNode()) - { - object = node->getObject(); - if(!object || !node->mValid) - { - // Clicked cancel - return; - } - if(object->getRegion() != region) - { - // Clicked cancel - return; - } - if (object->isAvatar()) - { - continue; - } - - if (object->getNVPair("AssetContainer")) - { - continue; - } - export_objects.push_back(node->getObject()); - export_names.push_back(node->mName); - export_descriptions.push_back(node->mDescription); - } - - if (export_objects.empty()) - { - return; - } - - // pick a save file - LLFilePicker& picker = LLFilePicker::instance(); - if (!picker.getSaveFile(LLFilePicker::FFSAVE_GEOMETRY, proposed_name)) - { - // Clicked cancel - return; - } - - // Copy the directory + file name - char filepath[LL_MAX_PATH]; /* Flawfinder: ignore */ - strncpy(filepath, picker.getFirstFile(), LL_MAX_PATH -1); /* Flawfinder: ignore */ - filepath[LL_MAX_PATH -1] = '\0'; - - apr_file_t* fp = ll_apr_file_open(filepath, LL_APR_W); - - if (!fp) - { - return; - } - - object = export_objects[object_index]; - LLVector3 baseoffset = object->getPositionRegion(); - - apr_file_printf(fp, "\n"); - apr_file_printf(fp, "\n"); - - while(object_index < export_objects.size()) - { - apr_file_printf(fp, "getPCode()); - apr_file_printf(fp, "\tMaterial='%d'\n", object->getMaterial()); - apr_file_printf(fp, "\tScale='%5f %5f %5f'\n", object->getScale().mV[VX], object->getScale().mV[VY], object->getScale().mV[VZ]); - LLVector3 delta = object->getPositionRegion() - baseoffset; - LLQuaternion rot = object->getRotationRegion(); - apr_file_printf(fp, "\tOffset='%5f %5f %5f'\n", delta.mV[VX], delta.mV[VY], delta.mV[VZ]); - apr_file_printf(fp, "\tOrientation='%5f %5f %5f %5f'\n", rot.mQ[VX], rot.mQ[VY], rot.mQ[VZ], rot.mQ[VS]); - const LLProfileParams pparams = object->getVolume()->getProfile().mParams; - apr_file_printf(fp, "\tShapeProfile='%d %f %f %f'\n", pparams.getCurveType(), pparams.getBegin(), pparams.getEnd(), pparams.getHollow()); - const LLPathParams paparams = object->getVolume()->getPath().mParams; - apr_file_printf(fp, "\tShapePath='%d %f %f %f %f %f %f %f %f %f %f %f %f %f'\n", - paparams.getCurveType(), paparams.getBegin(), paparams.getEnd(), paparams.getTwist(), paparams.getTwistBegin(), paparams.getScaleX(), paparams.getScaleY(), - paparams.getShearX(), paparams.getShearY(), paparams.getRadiusOffset(), paparams.getTaperX(), paparams.getTaperY(), - paparams.getRevolutions(), paparams.getSkew()); - S32 face, numfaces; - numfaces = object->getNumTEs(); - apr_file_printf(fp, "\tNumberOfFaces='%d'>\n", numfaces); - for (face = 0; face < numfaces; face++) - { - const LLTextureEntry *te = object->getTE(face); - LLColor4 color = te->getColor(); - apr_file_printf(fp, "\tgetID(); - texid.toString(texture); - F32 sx, sy, ox, oy; - te->getScale(&sx, &sy); - te->getOffset(&ox, &oy); - - apr_file_printf(fp, "\t\tFace='%d %5f %5f %5f %5f %5f %d %s'\n\t/>\n", face, sx, sy, ox, oy, te->getRotation(), te->getBumpShinyFullbright(), texture); - } - apr_file_printf(fp, "\n"); - object = export_objects[++object_index]; - } - - apr_file_printf(fp, "\n"); - - fclose(fp); -} - -void undo_find_local_contact_point(LLVector3 &contact, - const LLVector3& surface_norm, - const LLQuaternion& rot, - const LLVector3& scale ) -{ - LLVector3 local_norm = surface_norm; - local_norm.rotVec( ~rot ); - - LLVector3 v[6]; - v[0].mV[VX] = -1.f; - v[1].mV[VX] = 1.f; - - v[2].mV[VY] = -1.f; - v[3].mV[VY] = 1.f; - - v[4].mV[VZ] = -1.f; - v[5].mV[VZ] = 1.f; - - contact = v[0]; - F32 cur_val = 0; - - for( S32 i = 0; i < 6; i++ ) - { - F32 val = v[i] * local_norm; - if( val < cur_val ) - { - contact = v[i]; - cur_val = val; - } - } - - contact.mV[VX] *= 0.5f * scale.mV[VX]; - contact.mV[VY] *= 0.5f * scale.mV[VY]; - contact.mV[VZ] *= 0.5f * scale.mV[VZ]; - contact.rotVec( rot ); -} - - -void force_import_geometry(void*) +void handle_take() { - LLFilePicker& picker = LLFilePicker::instance(); - if (!picker.getOpenFile(LLFilePicker::FFLOAD_GEOMETRY)) - { - llinfos << "Couldn't import objects from file" << llendl; - return; - } - - char directory[LL_MAX_PATH]; /* Flawfinder: ignore */ - strncpy(directory, picker.getFirstFile(), LL_MAX_PATH -1); /* Flawfinder: ignore */ - directory[LL_MAX_PATH -1] = '\0'; - - llinfos << "Loading LSG file " << directory << llendl; - LLXmlTree *xmlparser = new LLXmlTree(); - xmlparser->parseFile(directory, TRUE); - LLXmlTreeNode *root = xmlparser->getRoot(); - if( !root ) - { - return; - } - // header - if( !root->hasName( "LindenGeometry" ) ) + // we want to use the folder this was derezzed from if it's + // available. Otherwise, derez to the normal place. + if(gSelectMgr->getSelection()->isEmpty()) { - llwarns << "Invalid LindenGeometry file header: " << directory << llendl; return; } - // objects - for (LLXmlTreeNode *child = root->getChildByName( "Object" ); - child; - child = root->getNextNamedChild()) - { - // get object data - // *NOTE: This buffer size is hard coded into scanf() below. - char name[255]; /* Flawfinder: ignore */ // Shape - char description[255]; /* Flawfinder: ignore */ // Description - U32 material; // Material - F32 sx, sy, sz; // Scale - LLVector3 scale; - F32 ox, oy, oz; // Offset - LLVector3 offset; - F32 rx, ry, rz, rs; // Orientation - LLQuaternion rot; - U32 curve; - F32 begin; - F32 end; - F32 hollow; - F32 twist; - F32 scx, scy; - F32 shx, shy; - F32 twist_begin; - F32 radius_offset; - F32 tx, ty; - F32 revolutions; - F32 skew; - S32 faces; - U32 pcode; - U32 flags = FLAGS_CREATE_SELECTED; - - LLString attribute; - - S32 count = 0; - - child->getAttributeString("PCode", &attribute); - pcode = atoi(attribute.c_str()); - child->getAttributeString("Shape", &attribute); - sscanf( /* Flawfinder: ignore */ - attribute.c_str(), "%254s", name); - child->getAttributeString("Description", &attribute); - sscanf( /* Flawfinder: ignore */ - attribute.c_str(), "%254s", description); - child->getAttributeString("Material", &attribute); - material = atoi(attribute.c_str()); - child->getAttributeString("Scale", &attribute); - sscanf(attribute.c_str(), "%f %f %f", &sx, &sy, &sz); - scale.setVec(sx, sy, sz); - child->getAttributeString("Offset", &attribute); - sscanf(attribute.c_str(), "%f %f %f", &ox, &oy, &oz); - offset.setVec(ox, oy, oz); - child->getAttributeString("Orientation", &attribute); - sscanf(attribute.c_str(), "%f %f %f %f", &rx, &ry, &rz, &rs); - rot.mQ[VX] = rx; - rot.mQ[VY] = ry; - rot.mQ[VZ] = rz; - rot.mQ[VS] = rs; - - child->getAttributeString("ShapeProfile", &attribute); - sscanf(attribute.c_str(), "%d %f %f %f", &curve, &begin, &end, &hollow); - LLProfileParams pparams(curve, begin, end, hollow); - child->getAttributeString("ShapePath", &attribute); - sscanf(attribute.c_str(), "%d %f %f %f %f %f %f %f %f %f %f %f %f %f", - &curve, &begin, &end, &twist, &twist_begin, &scx, &scy, &shx, ­, &radius_offset, &tx, &ty, &revolutions, &skew); - LLPathParams paparams(curve, begin, end, scx, scy, shx, shy, twist, twist_begin, radius_offset, tx, ty, revolutions, skew); - child->getAttributeString("NumberOfFaces", &attribute); - faces = atoi(attribute.c_str()); - - - - gMessageSystem->newMessageFast(_PREHASH_ObjectAdd); - gMessageSystem->nextBlockFast(_PREHASH_AgentData); - gMessageSystem->addUUIDFast(_PREHASH_AgentID, gAgent.getID()); - gMessageSystem->addUUIDFast(_PREHASH_SessionID, gAgent.getSessionID()); - gMessageSystem->addUUIDFast(_PREHASH_GroupID, gAgent.getGroupID()); - - gMessageSystem->nextBlockFast(_PREHASH_ObjectData); - gMessageSystem->addU8Fast(_PREHASH_PCode, pcode); - gMessageSystem->addU8Fast(_PREHASH_Material, material); - gMessageSystem->addU32Fast(_PREHASH_AddFlags, flags ); - pparams.packMessage(gMessageSystem); - paparams.packMessage(gMessageSystem); - - LLVector3 forward; - forward.setVec(3.f, 0.f, 1.f); - forward = forward * gAgent.getQuat(); - - LLVector3 start = gAgent.getPositionAgent() + forward; - - start += offset; - - // offset position to make up for error introduced by placement code - LLVector3 normal(0.f, 0.f, 1.f); - LLVector3 delta; - - undo_find_local_contact_point(delta, normal, rot, scale); - - start += delta; - - gMessageSystem->addVector3Fast(_PREHASH_Scale, scale ); - gMessageSystem->addQuatFast(_PREHASH_Rotation, rot ); - gMessageSystem->addVector3Fast(_PREHASH_RayStart, start ); - gMessageSystem->addVector3Fast(_PREHASH_RayEnd, start ); - gMessageSystem->addBOOLFast(_PREHASH_BypassRaycast, TRUE ); - gMessageSystem->addBOOLFast(_PREHASH_RayEndIsIntersection, FALSE ); - - U8 state = 0; - gMessageSystem->addU8Fast(_PREHASH_State, state); - - LLUUID ray_target_id; - gMessageSystem->addUUIDFast(_PREHASH_RayTargetID, ray_target_id ); - /* Setting TE info through ObjectAdd is no longer supported. - LLPrimitive temp_primitive; - temp_primitive.setNumTEs(faces); - for (LLXmlTreeNode *face = child->getChildByName( "Face" ); - face; - face = child->getNextNamedChild()) - { - // read the faces - U32 facenumber; - LLColor4 color; - // *NOTE: This buffer size is hard coded into scanf() below. - char texture[UUID_STR_LENGTH]; - LLUUID texid; - texid.toString(texture); - F32 sx, sy, ox, oy, rot; - U8 bump; - LLTextureEntry te; - - face->getAttributeString("FaceColor", &attribute); - sscanf(attribute, "%d %f %f %f %f", &facenumber, &color.mV[VX], &color.mV[VY], &color.mV[VZ], &color.mV[VW]); - face->getAttributeString("Face", &attribute); - sscanf(attribute, "%d %f %f %f %f %f %d %36s", &facenumber, &sx, &sy, &ox, &oy, &rot, &bump, texture); - texid.set(texture); - te.setColor(color); - te.setBumpShinyFullbright(bump); - te.setID(texid); - te.setRotation(rot); - te.setOffset(ox, oy); - te.setScale(sx, sy); - - temp_primitive.setTE(facenumber, te); - } - - temp_primitive.packTEMessage(gMessageSystem); - */ - gMessageSystem->sendReliable(gAgent.getRegionHost()); - } - -} -#endif - -void handle_take() -{ - // we want to use the folder this was derezzed from if it's - // available. Otherwise, derez to the normal place. - if(gSelectMgr->getSelection()->isEmpty()) return; - LLSelectNode* node = NULL; - LLViewerObject* object = NULL; BOOL you_own_everything = TRUE; - BOOL locked_but_takeable_object = FALSE; LLUUID category_id; - for(node = gSelectMgr->getSelection()->getFirstRootNode(); - node != NULL; - node = gSelectMgr->getSelection()->getNextRootNode()) + + for (LLObjectSelection::root_iterator iter = gSelectMgr->getSelection()->root_begin(); + iter != gSelectMgr->getSelection()->root_end(); iter++) { - object = node->getObject(); + LLSelectNode* node = *iter; + LLViewerObject* object = node->getObject(); if(object) { if(!object->permYouOwner()) @@ -4005,11 +3669,8 @@ void handle_take() } if(!object->permMove()) - { - locked_but_takeable_object = TRUE; - } } if(node->mFolderID.notNull()) @@ -4060,7 +3721,6 @@ void handle_take() } LLUUID* cat_id = new LLUUID(category_id); if(locked_but_takeable_object || - !you_own_everything) { if(locked_but_takeable_object && you_own_everything) @@ -4113,13 +3773,11 @@ BOOL enable_take() return FALSE; } - LLViewerObject* object = NULL; - for(LLSelectNode* node = gSelectMgr->getSelection()->getFirstRootNode(); - node != NULL; - node = gSelectMgr->getSelection()->getNextRootNode()) + for (LLObjectSelection::valid_root_iterator iter = gSelectMgr->getSelection()->valid_root_begin(); + iter != gSelectMgr->getSelection()->valid_root_end(); iter++) { - object = node->getObject(); - if(!object || !node->mValid) continue; + LLSelectNode* node = *iter; + LLViewerObject* object = node->getObject(); if (object->isAvatar()) { // ...don't acquire avatars @@ -4229,12 +3887,11 @@ class LLToolsEnableBuyOrTake : public view_listener_t // FALSE if selection is a 'take' BOOL is_selection_buy_not_take() { - LLViewerObject* obj = NULL; - for(LLSelectNode* node = gSelectMgr->getSelection()->getFirstRootNode(); - node != NULL; - node = gSelectMgr->getSelection()->getNextRootNode()) + for (LLObjectSelection::root_iterator iter = gSelectMgr->getSelection()->root_begin(); + iter != gSelectMgr->getSelection()->root_end(); iter++) { - obj = node->getObject(); + LLSelectNode* node = *iter; + LLViewerObject* obj = node->getObject(); if(obj && !(obj->permYouOwner()) && (node->mSaleInfo.isForSale())) { // you do not own the object and it is for sale, thus, @@ -4247,13 +3904,12 @@ BOOL is_selection_buy_not_take() S32 selection_price() { - LLViewerObject* obj = NULL; S32 total_price = 0; - for(LLSelectNode* node = gSelectMgr->getSelection()->getFirstRootNode(); - node != NULL; - node = gSelectMgr->getSelection()->getNextRootNode()) + for (LLObjectSelection::root_iterator iter = gSelectMgr->getSelection()->root_begin(); + iter != gSelectMgr->getSelection()->root_end(); iter++) { - obj = node->getObject(); + LLSelectNode* node = *iter; + LLViewerObject* obj = node->getObject(); if(obj && !(obj->permYouOwner()) && (node->mSaleInfo.isForSale())) { // you do not own the object and it is for sale. @@ -4393,12 +4049,11 @@ class LLToolsSnapObjectXY : public view_listener_t { F64 snap_size = (F64)gSavedSettings.getF32("GridResolution"); - LLViewerObject* obj; - LLObjectSelectionHandle selection = gSelectMgr->getSelection(); - for (obj = selection->getFirstRootObject(); - obj != NULL; - obj = selection->getNextRootObject()) + for (LLObjectSelection::root_iterator iter = gSelectMgr->getSelection()->root_begin(); + iter != gSelectMgr->getSelection()->root_end(); iter++) { + LLSelectNode* node = *iter; + LLViewerObject* obj = node->getObject(); if (obj->permModify()) { LLVector3d pos_global = obj->getPositionGlobal(); @@ -4455,17 +4110,15 @@ class LLToolsEnableLink : public view_listener_t { if(gSelectMgr->selectGetAllRootsValid() && gSelectMgr->getSelection()->getRootObjectCount() >= 2) { - LLObjectSelectionHandle selection = gSelectMgr->getSelection(); - for(LLViewerObject* object = selection->getFirstRootObject(); - object != NULL; - object = selection->getNextRootObject()) + struct f : public LLSelectedObjectFunctor { - if(object->permModify()) + virtual bool apply(LLViewerObject* object) { - new_value = true; - break; + return object->permModify(); } - } + } func; + const bool firstonly = true; + new_value = gSelectMgr->getSelection()->applyToRootObjects(&func, firstonly); } } gMenuHolder->findControl(userdata["control"].asString())->setValue(new_value); @@ -4903,7 +4556,6 @@ void handle_export_selected( void * ) return; } llinfos << "Exporting selected objects:" << llendl; - LLViewerObject *object = selection->getFirstRootObject(); gExporterRequestID.generate(); gExportDirectory = ""; @@ -4915,8 +4567,11 @@ void handle_export_selected( void * ) msg->addUUIDFast(_PREHASH_RequestID, gExporterRequestID); msg->addS16Fast(_PREHASH_VolumeDetail, 4); - for (; object != NULL; object = selection->getNextRootObject()) + for (LLObjectSelection::root_iterator iter = selection->root_begin(); + iter != selection->root_end(); iter++) { + LLSelectNode* node = *iter; + LLViewerObject* object = node->getObject(); msg->nextBlockFast(_PREHASH_ObjectData); msg->addUUIDFast(_PREHASH_ObjectID, object->getID()); llinfos << "Object: " << object->getID() << llendl; @@ -5310,16 +4965,21 @@ void handle_force_unlock(void*) gSelectMgr->sendOwner(LLUUID::null, LLUUID::null, TRUE); // Second, lie to the viewer and mark it editable and unowned - LLViewerObject* object; - for (object = gSelectMgr->getSelection()->getFirstObject(); object; object = gSelectMgr->getSelection()->getNextObject() ) + + struct f : public LLSelectedObjectFunctor { - object->mFlags |= FLAGS_OBJECT_MOVE; - object->mFlags |= FLAGS_OBJECT_MODIFY; - object->mFlags |= FLAGS_OBJECT_COPY; + virtual bool apply(LLViewerObject* object) + { + object->mFlags |= FLAGS_OBJECT_MOVE; + object->mFlags |= FLAGS_OBJECT_MODIFY; + object->mFlags |= FLAGS_OBJECT_COPY; - object->mFlags &= ~FLAGS_OBJECT_ANY_OWNER; - object->mFlags &= ~FLAGS_OBJECT_YOU_OWNER; - } + object->mFlags &= ~FLAGS_OBJECT_ANY_OWNER; + object->mFlags &= ~FLAGS_OBJECT_YOU_OWNER; + return true; + } + } func; + gSelectMgr->getSelection()->applyToObjects(&func); } // Fullscreen debug stuff @@ -5528,6 +5188,10 @@ class LLShowFloater : public view_listener_t LLFloaterBump::show(NULL); } } + else if (floater_name == "lag meter") + { + LLFloaterLagMeter::show(NULL); + } else if (floater_name == "bug reporter") { // Prevent menu from appearing in screen shot. @@ -6154,11 +5818,16 @@ class LLAttachmentEnableDetach : public view_listener_t BOOL object_selected_and_point_valid(void *user_data) { //LLViewerJointAttachment *attachment = (LLViewerJointAttachment *)user_data; - if (gSelectMgr == NULL) return FALSE; - + if (gSelectMgr == NULL) + { + return FALSE; + } LLObjectSelectionHandle selection = gSelectMgr->getSelection(); - for (LLViewerObject *object = selection->getFirstRootObject(); object; object = selection->getNextRootObject()) + for (LLObjectSelection::root_iterator iter = selection->root_begin(); + iter != selection->root_end(); iter++) { + LLSelectNode* node = *iter; + LLViewerObject* object = node->getObject(); for (U32 child_num = 0; child_num < object->mChildList.size(); child_num++ ) { if (object->mChildList[child_num]->isAvatar()) @@ -6230,12 +5899,68 @@ BOOL enable_activate(void*) return FALSE; } +namespace +{ + struct QueueObjects : public LLSelectedObjectFunctor + { + BOOL scripted; + BOOL modifiable; + LLFloaterScriptQueue* mQueue; + QueueObjects(LLFloaterScriptQueue* q) : mQueue(q), scripted(FALSE), modifiable(FALSE) {} + virtual bool apply(LLViewerObject* obj) + { + scripted = obj->flagScripted(); + modifiable = obj->permModify(); + + if( scripted && modifiable ) + { + mQueue->addObject(obj->getID()); + return false; + } + else + { + return true; // fail: stop applying + } + } + }; +} + +void queue_actions(LLFloaterScriptQueue* q, const std::string& noscriptmsg, const std::string& nomodmsg) +{ + // Apply until an object fails + QueueObjects func(q); + const bool firstonly = true; + bool fail = gSelectMgr->getSelection()->applyToObjects(&func, firstonly); + if(fail) + { + if ( !func.scripted ) + { + gViewerWindow->alertXml(noscriptmsg); + } + else if ( !func.modifiable ) + { + gViewerWindow->alertXml(nomodmsg); + } + else + { + llerrs << "Bad logic." << llendl; + } + } + else + { + if (!q->start()) + { + llwarns << "Unexpected script compile failure." << llendl; + } + } +} + class LLToolsSelectedScriptAction : public view_listener_t { bool handleEvent(LLPointer event, const LLSD& userdata) { LLString action = userdata.asString(); - LLFloaterScriptQueue *queue = NULL; + LLFloaterScriptQueue* queue = NULL; if (action == "compile") { queue = LLFloaterCompileQueue::create(); @@ -6252,35 +5977,13 @@ class LLToolsSelectedScriptAction : public view_listener_t { queue = LLFloaterNotRunQueue::create(); } - if (!queue) return true; - - BOOL scripted = FALSE; - BOOL modifiable = FALSE; - - for(LLViewerObject* obj = gSelectMgr->getSelection()->getFirstObject(); - obj; - obj = gSelectMgr->getSelection()->getNextObject()) + if (!queue) { - scripted = obj->flagScripted(); - modifiable = obj->permModify(); - - if( scripted && modifiable ) - queue->addObject(obj->getID()); - else - break; + return true; } - if(!queue->start()) - { - if ( ! scripted ) - { - gViewerWindow->alertXml("CannotRecompileSelectObjectsNoScripts"); - } - else if ( ! modifiable ) - { - gViewerWindow->alertXml("CannotRecompileSelectObjectsNoPermission"); - } - } + queue_actions(queue, "CannotRecompileSelectObjectsNoScripts", "CannotRecompileSelectObjectsNoPermission"); + return true; } }; @@ -6288,109 +5991,28 @@ class LLToolsSelectedScriptAction : public view_listener_t void handle_reset_selection(void*) { LLFloaterResetQueue* queue = LLFloaterResetQueue::create(); - - BOOL scripted = FALSE; - BOOL modifiable = FALSE; - - for(LLViewerObject* obj = gSelectMgr->getSelection()->getFirstObject(); - obj; - obj = gSelectMgr->getSelection()->getNextObject()) - { - scripted = obj->flagScripted(); - modifiable = obj->permModify(); - - if( scripted && modifiable ) - queue->addObject(obj->getID()); - else - break; - } - - if(!queue->start()) - { - if ( ! scripted ) - { - gViewerWindow->alertXml("CannotResetSelectObjectsNoScripts"); - } - else if ( ! modifiable ) - { - gViewerWindow->alertXml("CannotResetSelectObjectsNoPermission"); - } - } + queue_actions(queue, "CannotResetSelectObjectsNoScripts", "CannotResetSelectObjectsNoPermission"); } void handle_set_run_selection(void*) { LLFloaterRunQueue* queue = LLFloaterRunQueue::create(); - - BOOL scripted = FALSE; - BOOL modifiable = FALSE; - - for(LLViewerObject* obj = gSelectMgr->getSelection()->getFirstObject(); - obj; - obj = gSelectMgr->getSelection()->getNextObject()) - { - scripted = obj->flagScripted(); - modifiable = obj->permModify(); - - if( scripted && modifiable ) - queue->addObject(obj->getID()); - else - break; - } - - if(!queue->start()) - { - if ( ! scripted ) - { - gViewerWindow->alertXml("CannotSetRunningSelectObjectsNoScripts"); - } - else if ( ! modifiable ) - { - gViewerWindow->alertXml("CannotSerRunningSelectObjectsNoPermission"); - } - } + queue_actions(queue, "CannotSetRunningSelectObjectsNoScripts", "CannotSerRunningSelectObjectsNoPermission"); } void handle_set_not_run_selection(void*) { LLFloaterNotRunQueue* queue = LLFloaterNotRunQueue::create(); - - BOOL scripted = FALSE; - BOOL modifiable = FALSE; - - for(LLViewerObject* obj = gSelectMgr->getSelection()->getFirstObject(); - obj; - obj = gSelectMgr->getSelection()->getNextObject()) - { - scripted = obj->flagScripted(); - modifiable = obj->permModify(); - - if( scripted && modifiable ) - queue->addObject(obj->getID()); - else - break; - } - - if(!queue->start()) - { - if ( ! scripted ) - { - gViewerWindow->alertXml("CannotSetRunningNotSelectObjectsNoScripts"); - } - else if ( ! modifiable ) - { - gViewerWindow->alertXml("CannotSerRunningNotSelectObjectsNoPermission"); - } - } + queue_actions(queue, "CannotSetRunningNotSelectObjectsNoScripts", "CannotSerRunningNotSelectObjectsNoPermission"); } void handle_selected_texture_info(void*) { - LLSelectNode* node = NULL; - for (node = gSelectMgr->getSelection()->getFirstNode(); node != NULL; node = gSelectMgr->getSelection()->getNextNode()) + for (LLObjectSelection::valid_iterator iter = gSelectMgr->getSelection()->valid_begin(); + iter != gSelectMgr->getSelection()->valid_end(); iter++) { - if (!node->mValid) continue; - + LLSelectNode* node = *iter; + std::string msg; msg.assign("Texture info for: "); msg.append(node->mName); @@ -6610,51 +6232,52 @@ class LLToolsEnableTakeCopy : public view_listener_t { bool handleEvent(LLPointer event, const LLSD& userdata) { - bool new_value = false; + bool all_valid = false; if (gSelectMgr) { - new_value = true; + all_valid = true; #ifndef HACKED_GODLIKE_VIEWER # ifdef TOGGLE_HACKED_GODLIKE_VIEWER if (gInProductionGrid || !gAgent.isGodlike()) # endif { - LLObjectSelectionHandle selection = gSelectMgr->getSelection(); - LLViewerObject* obj = selection->getFirstRootObject(); - if(obj) + struct f : public LLSelectedObjectFunctor { - for( ; obj; obj = selection->getNextRootObject()) + virtual bool apply(LLViewerObject* obj) { - if(!(obj->permCopy()) || obj->isAttachment()) - { - new_value = false; - } + return (!obj->permCopy() || obj->isAttachment()); } - } + } func; + const bool firstonly = true; + bool any_invalid = gSelectMgr->getSelection()->applyToRootObjects(&func, firstonly); + all_valid = !any_invalid; } #endif // HACKED_GODLIKE_VIEWER } - gMenuHolder->findControl(userdata["control"].asString())->setValue(new_value); + gMenuHolder->findControl(userdata["control"].asString())->setValue(all_valid); return true; } }; BOOL enable_selection_you_own_all(void*) { - LLViewerObject *obj; if (gSelectMgr) { - LLObjectSelectionHandle selection = gSelectMgr->getSelection(); - for (obj = selection->getFirstRootObject(); obj; obj = selection->getNextRootObject()) + struct f : public LLSelectedObjectFunctor { - if (!obj->permYouOwner()) + virtual bool apply(LLViewerObject* obj) { - return FALSE; + return (!obj->permYouOwner()); } + } func; + const bool firstonly = true; + bool no_perms = gSelectMgr->getSelection()->applyToRootObjects(&func, firstonly); + if (no_perms) + { + return FALSE; } } - return TRUE; } @@ -6662,17 +6285,21 @@ BOOL enable_selection_you_own_one(void*) { if (gSelectMgr) { - LLObjectSelectionHandle selection = gSelectMgr->getSelection(); - LLViewerObject *obj; - for (obj = selection->getFirstRootObject(); obj; obj = selection->getNextRootObject()) + struct f : public LLSelectedObjectFunctor { - if (obj->permYouOwner()) + virtual bool apply(LLViewerObject* obj) { - return TRUE; + return (obj->permYouOwner()); } + } func; + const bool firstonly = true; + bool any_perms = gSelectMgr->getSelection()->applyToRootObjects(&func, firstonly); + if (!any_perms) + { + return FALSE; } } - return FALSE; + return TRUE; } class LLHasAsset : public LLInventoryCollectFunctor @@ -6703,13 +6330,13 @@ BOOL enable_save_into_inventory(void*) { if(gSelectMgr) { + // *TODO: clean this up // find the last root LLSelectNode* last_node = NULL; - for(LLSelectNode* node = gSelectMgr->getSelection()->getFirstRootNode(); - node != NULL; - node = gSelectMgr->getSelection()->getNextRootNode()) + for (LLObjectSelection::root_iterator iter = gSelectMgr->getSelection()->root_begin(); + iter != gSelectMgr->getSelection()->root_end(); iter++) { - last_node = node; + last_node = *iter; } #ifdef HACKED_GODLIKE_VIEWER @@ -7191,13 +6818,15 @@ class LLToolsUseSelectionForGrid : public view_listener_t bool handleEvent(LLPointer event, const LLSD& userdata) { gSelectMgr->clearGridObjects(); - LLObjectSelectionHandle selection = gSelectMgr->getSelection(); - for (LLViewerObject* objectp = selection->getFirstRootObject(); - objectp; - objectp = selection->getNextRootObject()) + struct f : public LLSelectedObjectFunctor + { + virtual bool apply(LLViewerObject* objectp) { gSelectMgr->addGridObject(objectp); + return true; } + } func; + gSelectMgr->getSelection()->applyToRootObjects(&func); gSelectMgr->setGridMode(GRID_MODE_REF_OBJECT); if (gFloaterTools) { @@ -7291,6 +6920,11 @@ void handle_load_from_xml(void*) } } +void handle_slurl_test(void*) +{ + LLFloaterHtml::getInstance()->show("http://user.lindenlab.com/~james/slurl.html", "SLURL Test"); +} + void handle_rebake_textures(void*) { LLVOAvatar* avatar = gAgent.getAvatarObject(); @@ -7774,6 +7408,7 @@ void initialize_menus() // Help menu addMenu(new LLHelpMOTD(), "Help.MOTD"); + // most items use the ShowFloater method // Self pie menu addMenu(new LLSelfStandUp(), "Self.StandUp"); diff --git a/linden/indra/newview/llviewermenu.h b/linden/indra/newview/llviewermenu.h index c223a3a..55fab86 100644 --- a/linden/indra/newview/llviewermenu.h +++ b/linden/indra/newview/llviewermenu.h @@ -2,6 +2,8 @@ * @file llviewermenu.h * @brief Builds menus out of objects * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERMENU_H diff --git a/linden/indra/newview/llviewermenufile.cpp b/linden/indra/newview/llviewermenufile.cpp index 031e6d4..97b11fd 100644 --- a/linden/indra/newview/llviewermenufile.cpp +++ b/linden/indra/newview/llviewermenufile.cpp @@ -2,6 +2,8 @@ * @file llviewermenufile.cpp * @brief "File" menu in the main menu bar. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -399,7 +402,7 @@ class LLFileTakeSnapshotToDisk : public view_listener_t gSavedSettings.getBOOL("RenderUIInSnapshot"), FALSE)) { - if (!gQuietSnapshot) + if (!gSavedSettings.getBOOL("QuietSnapshotsToDisk")) { gViewerWindow->playSnapshotAnimAndSound(); } diff --git a/linden/indra/newview/llviewermenufile.h b/linden/indra/newview/llviewermenufile.h index 32806fb..46255da 100644 --- a/linden/indra/newview/llviewermenufile.h +++ b/linden/indra/newview/llviewermenufile.h @@ -2,6 +2,8 @@ * @file llviewermenufile.h * @brief "File" menu in the main menu bar. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLVIEWERMENUFILE_H diff --git a/linden/indra/newview/llviewermessage.cpp b/linden/indra/newview/llviewermessage.cpp index 8f3cd96..bd959b9 100644 --- a/linden/indra/newview/llviewermessage.cpp +++ b/linden/indra/newview/llviewermessage.cpp @@ -2,6 +2,8 @@ * @file llviewermessage.cpp * @brief Dumping ground for viewer-side message system callbacks. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -31,8 +34,6 @@ #include "llviewermessage.h" #include -#include -#include #include "audioengine.h" #include "audiosettings.h" @@ -988,7 +989,7 @@ void inventory_offer_callback(S32 button, void* user_data) itemp = (LLViewerInventoryItem*)gInventory.getItem(info->mObjectID); } - // XUI:translate + // *TODO:translate LLString from_string; // Used in the pop-up. LLString chatHistory_string; // Used in chat history. if (info->mFromObject == TRUE) @@ -1104,7 +1105,7 @@ void inventory_offer_callback(S32 button, void* user_data) // Generates IM_INVENTORY_DECLINED, IM_TASK_INVENTORY_DECLINED, // or IM_GROUP_NOTICE_INVENTORY_DECLINED default: - // close button probably + // close button probably (or any of the fall-throughs from above) msg->addU8Fast(_PREHASH_Dialog, (U8)(info->mIM + 2)); msg->addBinaryDataFast(_PREHASH_BinaryBucket, EMPTY_BINARY_BUCKET, EMPTY_BINARY_BUCKET_SIZE); // send the message @@ -1139,7 +1140,7 @@ void inventory_offer_callback(S32 button, void* user_data) } } - if (busy || (!info->mFromGroup && !info->mFromObject)) + if (busy && (!info->mFromGroup && !info->mFromObject)) { busy_message(msg,info->mFromID); } @@ -1224,7 +1225,7 @@ void inventory_offer_handler(LLOfferInfo* info, BOOL from_task) } else { - // XUI:translate -> [FIRST] [LAST] + // *TODO:translate -> [FIRST] [LAST] args["[NAME]"] = info->mFromName; LLNotifyBox::showXml("UserGiveItem", args, &inventory_offer_callback, (void*)info); @@ -1328,7 +1329,7 @@ void process_improved_im(LLMessageSystem *msg, void **user_data) S32 binary_bucket_size; LLChat chat; - //XUI:translate - need to fix the full name to first/last + //*TODO:translate - need to fix the full name to first/last (maybe) msg->getUUIDFast(_PREHASH_AgentData, _PREHASH_AgentID, from_id); msg->getBOOLFast(_PREHASH_MessageBlock, _PREHASH_FromGroup, from_group); msg->getUUIDFast(_PREHASH_MessageBlock, _PREHASH_ToAgentID, to_id); @@ -1378,7 +1379,7 @@ void process_improved_im(LLMessageSystem *msg, void **user_data) case IM_CONSOLE_AND_CHAT_HISTORY: // These are used for system messages, hence don't need the name, // as it is always "Second Life". - // XUI:translate + // *TODO:translate args["[MESSAGE]"] = message; // Note: don't put the message in the IM history, even though was sent @@ -1527,7 +1528,7 @@ void process_improved_im(LLMessageSystem *msg, void **user_data) case IM_MESSAGEBOX: { // This is a block, modeless dialog. - //XUI:translate + //*TODO:translate args["[MESSAGE]"] = message; LLNotifyBox::showXml("SystemMessage", args); } @@ -1844,7 +1845,7 @@ void process_improved_im(LLMessageSystem *msg, void **user_data) } else { - // XUI:translate -> [FIRST] [LAST] + // *TODO:translate -> [FIRST] [LAST] (maybe) LLLureInfo* info = new LLLureInfo(from_id, session_id, FALSE); args["[NAME]"] = name; args["[MESSAGE]"] = message; @@ -2171,7 +2172,7 @@ void process_chat_from_simulator(LLMessageSystem *msg, void **user_data) if (gMuteListp) { is_muted = gMuteListp->isMuted(from_id, from_name, LLMute::flagTextChat) - || gMuteListp->isMuted(owner_id); + || gMuteListp->isMuted(owner_id, LLMute::flagTextChat); is_linden = chat.mSourceType != CHAT_SOURCE_OBJECT && gMuteListp->isLinden(from_name); } @@ -4025,7 +4026,7 @@ void process_money_balance_reply( LLMessageSystem* msg, void** ) { // Make the user confirm the transaction, since they might // have missed something during an event. - // XUI:translate + // *TODO:translate LLString::format_map_t args; args["[MESSAGE]"] = desc; LLNotifyBox::showXml("SystemMessage", args); @@ -4081,7 +4082,6 @@ void process_alert_core(const char* buffer, BOOL modal) gViewerWindow->saveSnapshot(snap_filename, gViewerWindow->getWindowWidth(), gViewerWindow->getWindowHeight(), FALSE, FALSE); } - // Translate system messages here. const char ALERT_PREFIX[] = "ALERT: "; const size_t ALERT_PREFIX_LEN = sizeof(ALERT_PREFIX) - 1; if (!strncmp(buffer, ALERT_PREFIX, ALERT_PREFIX_LEN)) @@ -4112,21 +4112,21 @@ void process_alert_core(const char* buffer, BOOL modal) } else { - //XUI:translate + // *TODO:translate args["[MESSAGE]"] = text; LLNotifyBox::showXml("SystemMessage", args); } } else if (modal) { - //XUI:translate + // *TODO:translate LLString::format_map_t args; args["[ERROR_MESSAGE]"] = buffer; gViewerWindow->alertXml("ErrorMessage", args); } else { - //XUI:translate + // *TODO:translate LLString::format_map_t args; args["[MESSAGE]"] = buffer; LLNotifyBox::showXml("SystemMessageTip", args); @@ -4427,7 +4427,7 @@ void script_question_cb(S32 option, void* user_data) void process_script_question(LLMessageSystem *msg, void **user_data) { - // XUI:translate owner name -> [FIRST] [LAST] + // *TODO:translate owner name -> [FIRST] [LAST] LLHost sender = msg->getSender(); diff --git a/linden/indra/newview/llviewermessage.h b/linden/indra/newview/llviewermessage.h index 7042324..2cbd163 100644 --- a/linden/indra/newview/llviewermessage.h +++ b/linden/indra/newview/llviewermessage.h @@ -2,6 +2,8 @@ * @file llviewermessage.h * @brief Message system callbacks for viewer. * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERMESSAGE_H diff --git a/linden/indra/newview/llviewernetwork.cpp b/linden/indra/newview/llviewernetwork.cpp index 4cdbd5c..046f1f6 100644 --- a/linden/indra/newview/llviewernetwork.cpp +++ b/linden/indra/newview/llviewernetwork.cpp @@ -3,6 +3,8 @@ * @author James Cook, Richard Nelson * @brief Networking constants and globals for viewer. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llviewernetwork.h b/linden/indra/newview/llviewernetwork.h index 1023182..1f73fe2 100644 --- a/linden/indra/newview/llviewernetwork.h +++ b/linden/indra/newview/llviewernetwork.h @@ -3,6 +3,8 @@ * @author James Cook * @brief Networking constants and globals for viewer. * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERNETWORK_H diff --git a/linden/indra/newview/llviewerobject.cpp b/linden/indra/newview/llviewerobject.cpp index ec81146..0c9ca01 100644 --- a/linden/indra/newview/llviewerobject.cpp +++ b/linden/indra/newview/llviewerobject.cpp @@ -2,6 +2,8 @@ * @file llviewerobject.cpp * @brief Base class for viewer objects * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -645,6 +648,29 @@ BOOL LLViewerObject::setDrawableParent(LLDrawable* parentp) return ret; } +// Show or hide particles, icon and HUD +void LLViewerObject::hideExtraDisplayItems( BOOL hidden ) +{ + if( mPartSourcep.notNull() ) + { + LLViewerPartSourceScript *partSourceScript = mPartSourcep.get(); + partSourceScript->setSuspended( hidden ); + } + + if( mText.notNull() ) + { + LLHUDText *hudText = mText.get(); + hudText->setHidden( hidden ); + } + + if( mIcon.notNull() ) + { + LLHUDIcon *hudIcon = mIcon.get(); + hudIcon->setHidden( hidden ); + } +} + + U32 LLViewerObject::processUpdateMessage(LLMessageSystem *mesgsys, void **user_data, U32 block_num, @@ -1596,23 +1622,8 @@ U32 LLViewerObject::processUpdateMessage(LLMessageSystem *mesgsys, sent_parentp->addChild(this); } - if( mPartSourcep.notNull() ) - { - LLViewerPartSourceScript *partSourceScript = mPartSourcep.get(); - partSourceScript->setSuspended( FALSE ); - } - - if( mText.notNull() ) - { - LLHUDText *hudText = mText.get(); - hudText->setHidden( FALSE ); - } - - if( mIcon.notNull() ) - { - LLHUDIcon *hudIcon = mIcon.get(); - hudIcon->setHidden( FALSE ); - } + // Show particles, icon and HUD + hideExtraDisplayItems( FALSE ); setChanged(MOVED | SILHOUETTE); } @@ -1628,23 +1639,9 @@ U32 LLViewerObject::processUpdateMessage(LLMessageSystem *mesgsys, U32 port = mesgsys->getSenderPort(); gObjectList.orphanize(this, parent_id, ip, port); - if( mPartSourcep.notNull() ) - { - LLViewerPartSourceScript *partSourceScript = mPartSourcep.get(); - partSourceScript->setSuspended( TRUE ); - } - - if( mText.notNull() ) - { - LLHUDText *hudText = mText.get(); - hudText->setHidden( TRUE ); - } - if( mIcon.notNull() ) - { - LLHUDIcon *hudIcon = mIcon.get(); - hudIcon->setHidden( TRUE ); - } + // Hide particles, icon and HUD + hideExtraDisplayItems( TRUE ); } } } @@ -4691,6 +4688,23 @@ void LLViewerObject::markForUpdate(BOOL priority) } } +bool LLViewerObject::getIncludeInSearch() const +{ + return ((mFlags & FLAGS_INCLUDE_IN_SEARCH) != 0); +} + +void LLViewerObject::setIncludeInSearch(bool include_in_search) +{ + if (include_in_search) + { + mFlags |= FLAGS_INCLUDE_IN_SEARCH; + } + else + { + mFlags &= ~FLAGS_INCLUDE_IN_SEARCH; + } +} + void LLViewerObject::setRegion(LLViewerRegion *regionp) { llassert(regionp); diff --git a/linden/indra/newview/llviewerobject.h b/linden/indra/newview/llviewerobject.h index 09b1d57..9ce417d 100644 --- a/linden/indra/newview/llviewerobject.h +++ b/linden/indra/newview/llviewerobject.h @@ -2,6 +2,8 @@ * @file llviewerobject.h * @brief Description of LLViewerObject class, which is the base class for most objects in the viewer. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWEROBJECT_H @@ -427,6 +430,9 @@ public: inline BOOL flagCameraSource() const { return ((mFlags & FLAGS_CAMERA_SOURCE) != 0); } inline BOOL flagCameraDecoupled() const { return ((mFlags & FLAGS_CAMERA_DECOUPLED) != 0); } + bool getIncludeInSearch() const; + void setIncludeInSearch(bool include_in_search); + // Does "open" object menu item apply? BOOL allowOpen() const; @@ -534,6 +540,9 @@ protected: BOOL setData(const U8 *datap, const U32 data_size); + // Hide or show HUD, icon and particles + void hideExtraDisplayItems( BOOL hidden ); + ////////////////////////// // // inventory functionality diff --git a/linden/indra/newview/llviewerobjectlist.cpp b/linden/indra/newview/llviewerobjectlist.cpp index f8c20a3..967f018 100644 --- a/linden/indra/newview/llviewerobjectlist.cpp +++ b/linden/indra/newview/llviewerobjectlist.cpp @@ -2,6 +2,8 @@ * @file llviewerobjectlist.cpp * @brief Implementation of LLViewerObjectList class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -589,12 +592,15 @@ void LLViewerObjectList::updateApparentAngles(LLAgent &agent) } // Selected - LLObjectSelectionHandle selection = gSelectMgr->getSelection(); - for (objectp = selection->getFirstRootObject(); objectp; objectp = selection->getNextRootObject()) + struct f : public LLSelectedObjectFunctor { - objectp->boostTexturePriority(); - } - + virtual bool apply(LLViewerObject* objectp) + { + objectp->boostTexturePriority(); + return true; + } + } func; + gSelectMgr->getSelection()->applyToRootObjects(&func); // Iterate through some of the objects and lazy update their texture priorities for (i = mCurLazyUpdateIndex; i < max_value; i++) @@ -1025,7 +1031,7 @@ void LLViewerObjectList::renderObjectsForMap(LLNetMap &netmap) for (S32 i = 0; i < mMapObjects.count(); i++) { LLViewerObject* objectp = mMapObjects[i]; - if (objectp->isOrphaned() || objectp->isAttachment()) + if (!objectp->getRegion() || objectp->isOrphaned() || objectp->isAttachment()) { continue; } @@ -1459,6 +1465,10 @@ void LLViewerObjectList::findOrphans(LLViewerObject* objectp, U32 ip, U32 port) childp->mDrawable->setState(LLDrawable::CLEAR_INVISIBLE); childp->setDrawableParent(objectp->mDrawable); // LLViewerObjectList::findOrphans() } + + // Make certain particles, icon and HUD aren't hidden + childp->hideExtraDisplayItems( FALSE ); + objectp->addChild(childp); orphans_found = TRUE; } diff --git a/linden/indra/newview/llviewerobjectlist.h b/linden/indra/newview/llviewerobjectlist.h index 309def1..f73a094 100644 --- a/linden/indra/newview/llviewerobjectlist.h +++ b/linden/indra/newview/llviewerobjectlist.h @@ -2,6 +2,8 @@ * @file llviewerobjectlist.h * @brief Description of LLViewerObjectList class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWEROBJECTLIST_H diff --git a/linden/indra/newview/llviewerparcelmgr.cpp b/linden/indra/newview/llviewerparcelmgr.cpp index 31c7d97..f0e8132 100644 --- a/linden/indra/newview/llviewerparcelmgr.cpp +++ b/linden/indra/newview/llviewerparcelmgr.cpp @@ -2,6 +2,8 @@ * @file llviewerparcelmgr.cpp * @brief Viewer-side representation of owned land * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -1249,7 +1252,7 @@ void LLViewerParcelMgr::makeLandmarkAtSelection() } */ -const char* LLViewerParcelMgr::getAgentParcelName() const +const LLString& LLViewerParcelMgr::getAgentParcelName() const { return mAgentParcel->getName(); } diff --git a/linden/indra/newview/llviewerparcelmgr.h b/linden/indra/newview/llviewerparcelmgr.h index a10163a..58a7067 100644 --- a/linden/indra/newview/llviewerparcelmgr.h +++ b/linden/indra/newview/llviewerparcelmgr.h @@ -2,6 +2,8 @@ * @file llviewerparcelmgr.h * @brief Viewer-side representation of owned land * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERPARCELMGR_H @@ -277,7 +280,7 @@ public: void sendParcelRelease(); // accessors for mAgentParcel - const char *getAgentParcelName() const; + const LLString& getAgentParcelName() const; // Create a landmark at the "appropriate" location for the // currently selected parcel. diff --git a/linden/indra/newview/llviewerparceloverlay.cpp b/linden/indra/newview/llviewerparceloverlay.cpp index e31b714..d9ab2bc 100644 --- a/linden/indra/newview/llviewerparceloverlay.cpp +++ b/linden/indra/newview/llviewerparceloverlay.cpp @@ -2,6 +2,8 @@ * @file llviewerparceloverlay.cpp * @brief LLViewerParcelOverlay class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llviewerparceloverlay.h b/linden/indra/newview/llviewerparceloverlay.h index d444d96..f134795 100644 --- a/linden/indra/newview/llviewerparceloverlay.h +++ b/linden/indra/newview/llviewerparceloverlay.h @@ -2,6 +2,8 @@ * @file llviewerparceloverlay.h * @brief LLViewerParcelOverlay class header file * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERPARCELOVERLAY_H diff --git a/linden/indra/newview/llviewerpartsim.cpp b/linden/indra/newview/llviewerpartsim.cpp index bc15317..acae8d3 100644 --- a/linden/indra/newview/llviewerpartsim.cpp +++ b/linden/indra/newview/llviewerpartsim.cpp @@ -2,6 +2,8 @@ * @file llviewerpartsim.cpp * @brief LLViewerPart class implementation * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -417,6 +420,18 @@ void LLViewerPartGroup::shift(const LLVector3 &offset) } } +void LLViewerPartGroup::removeParticlesByID(const U32 source_id) +{ + LLMemType mt(LLMemType::MTYPE_PARTICLES); + S32 end = (S32) mParticles.size(); + for (int i = 0; i < end; i++) + { + if(mParticles[i]->mPartSourcep->getID() == source_id) + { + mParticles[i]->mFlags = LLViewerPart::LL_PART_DEAD_MASK; + } + } +} ////////////////////////////////// // @@ -684,6 +699,10 @@ void LLViewerPartSim::addPartSource(LLPointer sourcep) mViewerPartSources.push_back(sourcep); } +void LLViewerPartSim::removeLastCreatedSource() +{ + mViewerPartSources.pop_back(); +} void LLViewerPartSim::cleanupRegion(LLViewerRegion *regionp) { @@ -700,16 +719,32 @@ void LLViewerPartSim::cleanupRegion(LLViewerRegion *regionp) } } -void LLViewerPartSim::cleanMutedParticles(const LLUUID& task_id) +void LLViewerPartSim::clearParticlesByID(const U32 system_id) { LLMemType mt(LLMemType::MTYPE_PARTICLES); - for (source_list_t::iterator i = mViewerPartSources.begin(); i != mViewerPartSources.end(); ) + for (group_list_t::iterator g = mViewerPartGroups.begin(); g != mViewerPartGroups.end(); ++g) { - source_list_t::iterator iter = i++; + (*g)->removeParticlesByID(system_id); + } + for (source_list_t::iterator i = mViewerPartSources.begin(); i != mViewerPartSources.end(); ++i) + { + if ((*i)->getID() == system_id) + { + (*i)->setDead(); + break; + } + } + +} +void LLViewerPartSim::clearParticlesByOwnerID(const LLUUID& task_id) +{ + LLMemType mt(LLMemType::MTYPE_PARTICLES); + for (source_list_t::iterator iter = mViewerPartSources.begin(); iter != mViewerPartSources.end(); ++iter) + { if ((*iter)->getOwnerUUID() == task_id) { - i = mViewerPartSources.erase(iter); + clearParticlesByID((*iter)->getID()); } } } diff --git a/linden/indra/newview/llviewerpartsim.h b/linden/indra/newview/llviewerpartsim.h index 0dc4324..c915468 100644 --- a/linden/indra/newview/llviewerpartsim.h +++ b/linden/indra/newview/llviewerpartsim.h @@ -2,6 +2,8 @@ * @file llviewerpartsim.h * @brief LLViewerPart class header file * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERPARTSIM_H @@ -107,6 +110,8 @@ public: S32 getCount() const { return (S32) mParticles.size(); } LLViewerRegion *getRegion() const { return mRegionp; } + void removeParticlesByID(const U32 source_id); + LLPointer mVOPartGroupp; BOOL mUniformParticles; @@ -126,10 +131,14 @@ protected: class LLViewerPartSim { + public: LLViewerPartSim(); virtual ~LLViewerPartSim(); + typedef std::vector group_list_t; + typedef std::vector > source_list_t; + void shift(const LLVector3 &offset); void updateSimulation(); @@ -140,7 +149,11 @@ public: BOOL shouldAddPart(); // Just decides whether this particle should be added or not (for particle count capping) void addPart(LLViewerPart* part); - void cleanMutedParticles(const LLUUID& task_id); + void clearParticlesByID(const U32 system_id); + void clearParticlesByOwnerID(const LLUUID& task_id); + void removeLastCreatedSource(); + + const source_list_t* getParticleSystemList() const { return &mViewerPartSources; } friend class LLViewerPartGroup; @@ -158,8 +171,6 @@ protected: LLViewerPartGroup *put(LLViewerPart* part); protected: - typedef std::vector group_list_t; - typedef std::vector > source_list_t; group_list_t mViewerPartGroups; source_list_t mViewerPartSources; LLFrameTimer mSimulationTimer; diff --git a/linden/indra/newview/llviewerpartsource.cpp b/linden/indra/newview/llviewerpartsource.cpp index 836748a..a69fc51 100644 --- a/linden/indra/newview/llviewerpartsource.cpp +++ b/linden/indra/newview/llviewerpartsource.cpp @@ -2,6 +2,8 @@ * @file llviewerpartsource.cpp * @brief LLViewerPartSource class implementation * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -67,7 +70,15 @@ void LLViewerPartSource::update(const F32 dt) llerrs << "Creating default part source!" << llendl; } - +LLUUID LLViewerPartSource::getImageUUID() const +{ + LLViewerImage* imagep = mImagep; + if(imagep) + { + return imagep->getID(); + } + return LLUUID::null; +} LLViewerPartSourceScript::LLViewerPartSourceScript(LLViewerObject *source_objp) : LLViewerPartSource(LL_PART_SOURCE_SCRIPT) diff --git a/linden/indra/newview/llviewerpartsource.h b/linden/indra/newview/llviewerpartsource.h index 32e1475..3e3e63c 100644 --- a/linden/indra/newview/llviewerpartsource.h +++ b/linden/indra/newview/llviewerpartsource.h @@ -2,6 +2,8 @@ * @file llviewerpartsource.h * @brief LLViewerPartSource class header file * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERPARTSOURCE_H @@ -68,6 +71,8 @@ public: static void updatePart(LLViewerPart &part, const F32 dt); void setOwnerUUID(const LLUUID& owner_id) { mOwnerUUID = owner_id; } LLUUID getOwnerUUID() const { return mOwnerUUID; } + U32 getID() const { return mID; } + LLUUID getImageUUID() const; LLVector3 mPosAgent; // Location of the particle source LLVector3 mTargetPosAgent; // Location of the target position @@ -82,7 +87,8 @@ protected: F32 mLastUpdateTime; F32 mLastPartTime; LLUUID mOwnerUUID; - + LLPointer mImagep; + // Particle information U32 mPartFlags; // Flags for the particle }; @@ -120,7 +126,6 @@ public: protected: LLQuaternion mRotation; // Current rotation for particle source - LLPointer mImagep; // Cached image pointer of the mPartSysData UUID LLPointer mTargetObjectp; // Target object for the particle source }; @@ -145,7 +150,6 @@ public: static void updatePart(LLViewerPart &part, const F32 dt); LLColor4 mColor; protected: - LLPointer mImagep; LLVector3d mLKGSourcePosGlobal; }; @@ -171,7 +175,6 @@ public: void setColor(const LLColor4 &color); static void updatePart(LLViewerPart &part, const F32 dt); - LLPointer mImagep; LLPointer mTargetObjectp; LLVector3d mLKGTargetPosGlobal; LLColor4 mColor; @@ -197,11 +200,9 @@ public: void setSourceObject(LLViewerObject *objp); void setColor(const LLColor4 &color); - static void updatePart(LLViewerPart &part, const F32 dt); LLColor4 mColor; protected: - LLPointer mImagep; LLVector3d mLKGSourcePosGlobal; }; diff --git a/linden/indra/newview/llviewerprecompiledheaders.cpp b/linden/indra/newview/llviewerprecompiledheaders.cpp index 16ac4a7..6dcca67 100644 --- a/linden/indra/newview/llviewerprecompiledheaders.cpp +++ b/linden/indra/newview/llviewerprecompiledheaders.cpp @@ -2,6 +2,8 @@ * @file llviewerprecompiledheaders.cpp * @brief precompiled headers for newview project * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // source file that includes just the standard includes diff --git a/linden/indra/newview/llviewerprecompiledheaders.h b/linden/indra/newview/llviewerprecompiledheaders.h index f5a66a7..ffcf31b 100644 --- a/linden/indra/newview/llviewerprecompiledheaders.h +++ b/linden/indra/newview/llviewerprecompiledheaders.h @@ -3,6 +3,8 @@ * @brief precompiled headers for newview project * @author James Cook * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ diff --git a/linden/indra/newview/llviewerregion.cpp b/linden/indra/newview/llviewerregion.cpp index 6378b01..0a8d9a8 100644 --- a/linden/indra/newview/llviewerregion.cpp +++ b/linden/indra/newview/llviewerregion.cpp @@ -2,6 +2,8 @@ * @file llviewerregion.cpp * @brief Implementation of the LLViewerRegion class. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -51,6 +54,7 @@ #include "llfloaterregioninfo.h" #include "llhttpnode.h" #include "llnetmap.h" +#include "llsdutil.h" #include "llstartup.h" #include "llviewerobjectlist.h" #include "llviewerparceloverlay.h" @@ -447,6 +451,7 @@ std::string LLViewerRegion::regionFlagsToString(U32 flags) return result; } +// *TODO:Translate char* SIM_ACCESS_STR[] = { "Free Trial", "PG", "Mature", @@ -825,6 +830,88 @@ BOOL LLViewerRegion::isOwnedGroup(const LLVector3& pos) } } +// the new TCP coarse location handler node +class CoarseLocationUpdate : public LLHTTPNode +{ +public: + virtual void post( + ResponsePtr responder, + const LLSD& context, + const LLSD& input) const + { + LLHost host(input["sender"].asString()); + LLViewerRegion* region = gWorldp->getRegion(host); + if( !region ) + { + return; + } + + S32 target_index = input["body"]["Index"][0]["Prey"].asInteger(); + S32 you_index = input["body"]["Index"][0]["You" ].asInteger(); + + LLDynamicArray* avatar_locs = ®ion->mMapAvatars; + LLDynamicArray* avatar_ids = ®ion->mMapAvatarIDs; + avatar_locs->reset(); + avatar_ids->reset(); + + //llinfos << "coarse locations agent[0] " << input["body"]["AgentData"][0]["AgentID"].asUUID() << llendl; + //llinfos << "my agent id = " << gAgent.getID() << llendl; + //llinfos << ll_pretty_print_sd(input) << llendl; + + LLSD + locs = input["body"]["Location"], + agents = input["body"]["AgentData"]; + LLSD::array_iterator + locs_it = locs.beginArray(), + agents_it = agents.beginArray(); + BOOL has_agent_data = input["body"].has("AgentData"); + + for(int i=0; + locs_it != locs.endArray(); + i++, locs_it++, agents_it++) + { + U8 + x = locs_it->get("X").asInteger(), + y = locs_it->get("Y").asInteger(), + z = locs_it->get("Z").asInteger(); + // treat the target specially for the map, and don't add you or the target + if(i == target_index) + { + LLVector3d global_pos(region->getOriginGlobal()); + global_pos.mdV[VX] += (F64)x; + global_pos.mdV[VY] += (F64)y; + global_pos.mdV[VZ] += (F64)z * 4.0; + LLAvatarTracker::instance().setTrackedCoarseLocation(global_pos); + } + else if( i != you_index) + { + U32 loc = x << 16 | y << 8 | z; loc = loc; + U32 pos = 0x0; + pos |= x; + pos <<= 8; + pos |= y; + pos <<= 8; + pos |= z; + avatar_locs->put(pos); + //llinfos << "next pos: " << x << "," << y << "," << z << ": " << pos << llendl; + if(has_agent_data) // for backwards compatibility with old message format + { + LLUUID agent_id(agents_it->get("AgentID").asUUID()); + //llinfos << "next agent: " << agent_id.asString() << llendl; + avatar_ids->put(agent_id); + } + } + } + } +}; + +// build the coarse location HTTP node under the "/message" URL +LLHTTPRegistration + gHTTPRegistrationCoarseLocationUpdate( + "/message/CoarseLocationUpdate"); + + +// the deprecated coarse location handler void LLViewerRegion::updateCoarseLocations(LLMessageSystem* msg) { //llinfos << "CoarseLocationUpdate" << llendl; @@ -1274,9 +1361,11 @@ void LLViewerRegion::setSeedCapability(const std::string& url) capabilityNames.append("UntrustedSimulatorMessage"); capabilityNames.append("ParcelVoiceInfoRequest"); capabilityNames.append("ChatSessionRequest"); + capabilityNames.append("ViewerStats"); capabilityNames.append("ProvisionVoiceAccountRequest"); capabilityNames.append("ServerReleaseNotes"); capabilityNames.append("CopyInventoryFromNotecard"); + capabilityNames.append("DispatchRegionInfo"); llinfos << "posting to seed " << url << llendl; @@ -1325,3 +1414,4 @@ void LLViewerRegion::logActiveCapabilities() const llinfos << "Dumped " << count << " entries." << llendl; } + diff --git a/linden/indra/newview/llviewerregion.h b/linden/indra/newview/llviewerregion.h index 6407f0c..d759361 100644 --- a/linden/indra/newview/llviewerregion.h +++ b/linden/indra/newview/llviewerregion.h @@ -2,6 +2,8 @@ * @file llviewerregion.h * @brief Description of the LLViewerRegion class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERREGION_H @@ -262,7 +265,13 @@ public: LLStat mPacketsStat; LLStat mPacketsLostStat; + // These arrays are maintained in parallel. Ideally they'd be combined into a + // single array of an aggrigate data type but for compatibility with the old + // messaging system in which the previous message only sends and parses the + // positions stored in the first array so they're maintained separately until + // we stop supporting the old CoarseLocationUpdate message. LLDynamicArray mMapAvatars; + LLDynamicArray mMapAvatarIDs; protected: // The surfaces and other layers @@ -388,3 +397,4 @@ inline BOOL LLViewerRegion::getRestrictPushObject() const #endif + diff --git a/linden/indra/newview/llviewerstats.cpp b/linden/indra/newview/llviewerstats.cpp index 4ad1155..da75de6 100644 --- a/linden/indra/newview/llviewerstats.cpp +++ b/linden/indra/newview/llviewerstats.cpp @@ -2,6 +2,8 @@ * @file llviewerstats.cpp * @brief LLViewerStats class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -288,17 +291,18 @@ void LLViewerStats::updateFrameStats(const F64 time_diff) } -void LLViewerStats::addToMessage() const +void LLViewerStats::addToMessage(LLSD &body) const { + LLSD &misc = body["misc"]; + for (S32 i = 0; i < ST_COUNT; i++) { if (STAT_INFO[i].mEnabled) { // TODO: send timer value so dataserver can normalize - gMessageSystem->nextBlockFast(_PREHASH_MiscStats); - gMessageSystem->addU32Fast(_PREHASH_Type, (U32)i); - gMessageSystem->addF64Fast(_PREHASH_Value, mStats[i]); - llinfos << "STAT: " << STAT_INFO[i].mName << ": " << mStats[i] << llendl; + misc[STAT_INFO[i].mName] = mStats[i]; + llinfos << "STAT: " << STAT_INFO[i].mName << ": " << mStats[i] + << llendl; } } } diff --git a/linden/indra/newview/llviewerstats.h b/linden/indra/newview/llviewerstats.h index 81650dd..9e42f29 100644 --- a/linden/indra/newview/llviewerstats.h +++ b/linden/indra/newview/llviewerstats.h @@ -2,6 +2,8 @@ * @file llviewerstats.h * @brief LLViewerStats class header file * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERSTATS_H @@ -172,7 +175,7 @@ public: void updateFrameStats(const F64 time_diff); - void addToMessage() const; + void addToMessage(LLSD &body) const; static const char *statTypeToText(EStatType type); diff --git a/linden/indra/newview/llviewertexteditor.cpp b/linden/indra/newview/llviewertexteditor.cpp index 754132d..2c382cb 100644 --- a/linden/indra/newview/llviewertexteditor.cpp +++ b/linden/indra/newview/llviewertexteditor.cpp @@ -2,6 +2,8 @@ * @file llviewertexteditor.cpp * @brief Text editor widget to let users enter a a multi-line ASCII document. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llviewertexteditor.h b/linden/indra/newview/llviewertexteditor.h index 230ce3e..e05a61c 100644 --- a/linden/indra/newview/llviewertexteditor.h +++ b/linden/indra/newview/llviewertexteditor.h @@ -2,6 +2,8 @@ * @file llviewertexteditor.h * @brief Text editor widget to let users enter a a multi-line document// * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_VIEWERTEXTEDITOR_H @@ -47,7 +50,7 @@ public: LLViewerTextEditor(const LLString& name, const LLRect& rect, S32 max_length, - const LLString& default_text = "", + const LLString& default_text = LLString(), const LLFontGL* glfont = NULL, BOOL allow_embedded_items = FALSE); diff --git a/linden/indra/newview/llviewertextureanim.cpp b/linden/indra/newview/llviewertextureanim.cpp index d608088..1c7eed7 100644 --- a/linden/indra/newview/llviewertextureanim.cpp +++ b/linden/indra/newview/llviewertextureanim.cpp @@ -2,6 +2,8 @@ * @file llviewertextureanim.cpp * @brief LLViewerTextureAnim class implementation * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llviewertextureanim.h b/linden/indra/newview/llviewertextureanim.h index 0477455..57626dd 100644 --- a/linden/indra/newview/llviewertextureanim.h +++ b/linden/indra/newview/llviewertextureanim.h @@ -2,6 +2,8 @@ * @file llviewertextureanim.h * @brief LLViewerTextureAnim class header file * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERTEXTUREANIM_H diff --git a/linden/indra/newview/llviewerthrottle.cpp b/linden/indra/newview/llviewerthrottle.cpp index 1db94ec..d427cd6 100644 --- a/linden/indra/newview/llviewerthrottle.cpp +++ b/linden/indra/newview/llviewerthrottle.cpp @@ -2,6 +2,8 @@ * @file llviewerthrottle.cpp * @brief LLViewerThrottle class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llviewerthrottle.h b/linden/indra/newview/llviewerthrottle.h index e56e623..4ef5808 100644 --- a/linden/indra/newview/llviewerthrottle.h +++ b/linden/indra/newview/llviewerthrottle.h @@ -2,6 +2,8 @@ * @file llviewerthrottle.h * @brief LLViewerThrottle class header file * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERTHROTTLE_H diff --git a/linden/indra/newview/llvieweruictrlfactory.cpp b/linden/indra/newview/llvieweruictrlfactory.cpp index 188c905..962f1de 100644 --- a/linden/indra/newview/llvieweruictrlfactory.cpp +++ b/linden/indra/newview/llvieweruictrlfactory.cpp @@ -2,6 +2,8 @@ * @file llvieweruictrlfactory.cpp * @brief factory class for creating UI controls * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llvieweruictrlfactory.h b/linden/indra/newview/llvieweruictrlfactory.h index 9664732..5a1689e 100644 --- a/linden/indra/newview/llvieweruictrlfactory.h +++ b/linden/indra/newview/llvieweruictrlfactory.h @@ -2,6 +2,8 @@ * @file llvieweruictrlfactory.h * @brief factory class for creating UI controls * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVIEWERUICTRLFACTORY_H diff --git a/linden/indra/newview/llviewervisualparam.cpp b/linden/indra/newview/llviewervisualparam.cpp index fd6561d..3999eb0 100644 --- a/linden/indra/newview/llviewervisualparam.cpp +++ b/linden/indra/newview/llviewervisualparam.cpp @@ -2,6 +2,8 @@ * @file llviewervisualparam.cpp * @brief Implementation of LLViewerVisualParam class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //----------------------------------------------------------------------------- diff --git a/linden/indra/newview/llviewervisualparam.h b/linden/indra/newview/llviewervisualparam.h index 9f469e5..b115fec 100644 --- a/linden/indra/newview/llviewervisualparam.h +++ b/linden/indra/newview/llviewervisualparam.h @@ -2,6 +2,8 @@ * @file llviewervisualparam.h * @brief viewer side visual params (with data file parsing) * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLViewerVisualParam_H diff --git a/linden/indra/newview/llviewerwindow.cpp b/linden/indra/newview/llviewerwindow.cpp index fb52827..49abf13 100644 --- a/linden/indra/newview/llviewerwindow.cpp +++ b/linden/indra/newview/llviewerwindow.cpp @@ -2,6 +2,8 @@ * @file llviewerwindow.cpp * @brief Implementation of the LLViewerWindow class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,15 +26,11 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" -// system library includes -#include -#include -#include - #include "llviewerwindow.h" #include "llviewquery.h" #include "llxmltree.h" @@ -156,6 +154,7 @@ #include "lltoolview.h" #include "llvieweruictrlfactory.h" #include "lluploaddialog.h" +#include "llurldispatcher.h" // SLURL from other app instance #include "llviewercamera.h" #include "llviewergesture.h" #include "llviewerimagelist.h" @@ -1219,6 +1218,10 @@ void LLViewerWindow::handleFocus(LLWindow *window) { gKeyboard->resetMaskKeys(); } + + // resume foreground running timer + // since we artifically limit framerate when not frontmost + gForegroundTime.unpause(); } // The top-level window has lost focus (e.g. via ALT-TAB) @@ -1252,6 +1255,9 @@ void LLViewerWindow::handleFocusLost(LLWindow *window) { gKeyboard->resetKeys(); } + + // pause timer that tracks total foreground running time + gForegroundTime.pause(); } @@ -1329,10 +1335,16 @@ BOOL LLViewerWindow::handleActivate(LLWindow *window, BOOL activated) else { mActive = FALSE; - if (gAllowIdleAFK) { + if (gAllowIdleAFK) + { gAgent.setAFK(); } + + // SL-53351: Make sure we're not in mouselook when minimised, to prevent control issues + gAgent.changeCameraToDefault(); + send_agent_pause(); + if (mWindow->getFullscreen() && !mIgnoreActivate) { llinfos << "Stopping GL during deactivation" << llendl; @@ -1414,22 +1426,14 @@ void LLViewerWindow::handleWindowUnblock(LLWindow *window) void LLViewerWindow::handleDataCopy(LLWindow *window, S32 data_type, void *data) { + const S32 SLURL_MESSAGE_TYPE = 0; switch (data_type) { - case 0: + case SLURL_MESSAGE_TYPE: // received URL - if (LLURLSimString::unpack_data(data)) + std::string url = (const char*)data; + if (LLURLDispatcher::dispatch(url)) { - if(gFloaterWorldMap) - { - gFloaterWorldMap->trackURL(LLURLSimString::sInstance.mSimName, - LLURLSimString::sInstance.mX, - LLURLSimString::sInstance.mY, - LLURLSimString::sInstance.mZ); - - LLFloaterWorldMap::show(NULL, TRUE); - } - // bring window to foreground, as it has just been "launched" from a URL mWindow->bringToFront(); } @@ -1820,6 +1824,8 @@ void LLViewerWindow::adjustRectanglesForFirstUse(const LLRect& window) adjust_rect_top_right("FloaterMapRect", window); + adjust_rect_top_right("FloaterLagMeter", window); + adjust_rect_top_left("FloaterBuildOptionsRect", window); // bottom-right @@ -3106,7 +3112,6 @@ void LLViewerWindow::saveLastMouse(const LLCoordGL &point) // render_hud_elements: FALSE, FALSE, FALSE void LLViewerWindow::renderSelections( BOOL for_gl_pick, BOOL pick_parcel_walls, BOOL for_hud ) { - LLViewerObject* object; LLObjectSelectionHandle selection = gSelectMgr->getSelection(); if (!for_hud && !for_gl_pick) @@ -3162,34 +3167,41 @@ void LLViewerWindow::renderSelections( BOOL for_gl_pick, BOOL pick_parcel_walls, F32 zoom = gAgent.getAvatarObject()->mHUDCurZoom; glScalef(zoom, zoom, zoom); } - for( object = gSelectMgr->getSelection()->getFirstObject(); object; object = gSelectMgr->getSelection()->getNextObject() ) + + struct f : public LLSelectedObjectFunctor { - LLDrawable* drawable = object->mDrawable; - if (drawable && drawable->isLight()) + virtual bool apply(LLViewerObject* object) { - LLVOVolume* vovolume = drawable->getVOVolume(); - glPushMatrix(); + LLDrawable* drawable = object->mDrawable; + if (drawable && drawable->isLight()) + { + LLVOVolume* vovolume = drawable->getVOVolume(); + glPushMatrix(); - LLVector3 center = drawable->getPositionAgent(); - glTranslatef(center[0], center[1], center[2]); - F32 scale = vovolume->getLightRadius(); - glScalef(scale, scale, scale); + LLVector3 center = drawable->getPositionAgent(); + glTranslatef(center[0], center[1], center[2]); + F32 scale = vovolume->getLightRadius(); + glScalef(scale, scale, scale); - LLColor4 color(vovolume->getLightColor(), .5f); - glColor4fv(color.mV); + LLColor4 color(vovolume->getLightColor(), .5f); + glColor4fv(color.mV); - F32 pixel_area = 100000.f; - // Render Outside - gSphere.render(pixel_area); - - // Render Inside - glCullFace(GL_FRONT); - gSphere.render(pixel_area); - glCullFace(GL_BACK); + F32 pixel_area = 100000.f; + // Render Outside + gSphere.render(pixel_area); + + // Render Inside + glCullFace(GL_FRONT); + gSphere.render(pixel_area); + glCullFace(GL_BACK); - glPopMatrix(); + glPopMatrix(); + } + return true; } - } + } func; + gSelectMgr->getSelection()->applyToObjects(&func); + glPopMatrix(); } @@ -3212,8 +3224,12 @@ void LLViewerWindow::renderSelections( BOOL for_gl_pick, BOOL pick_parcel_walls, BOOL all_selected_objects_move = TRUE; BOOL all_selected_objects_modify = TRUE; BOOL selecting_linked_set = !gSavedSettings.getBOOL("EditLinkedParts"); - for( object = gSelectMgr->getSelection()->getFirstObject(); object; object = gSelectMgr->getSelection()->getNextObject() ) + + for (LLObjectSelection::iterator iter = gSelectMgr->getSelection()->begin(); + iter != gSelectMgr->getSelection()->end(); iter++) { + LLSelectNode* nodep = *iter; + LLViewerObject* object = nodep->getObject(); BOOL this_object_movable = FALSE; if (object->permMove() && (object->permModify() || selecting_linked_set)) { diff --git a/linden/indra/newview/llviewerwindow.h b/linden/indra/newview/llviewerwindow.h index 4560427..fcd1597 100644 --- a/linden/indra/newview/llviewerwindow.h +++ b/linden/indra/newview/llviewerwindow.h @@ -2,6 +2,8 @@ * @file llviewerwindow.h * @brief Description of the LLViewerWindow class. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // @@ -217,7 +220,7 @@ public: BOOL saveSnapshot(const LLString& filename, S32 image_width, S32 image_height, BOOL show_ui = TRUE, BOOL do_rebuild = FALSE, ESnapshotType type = SNAPSHOT_TYPE_COLOR); BOOL rawSnapshot(LLImageRaw *raw, S32 image_width, S32 image_height, BOOL keep_window_aspect = TRUE, BOOL show_ui = TRUE, BOOL do_rebuild = FALSE, ESnapshotType type = SNAPSHOT_TYPE_COLOR ); - BOOL saveImageNumbered(LLImageRaw *raw, const LLString& extension = ""); + BOOL saveImageNumbered(LLImageRaw *raw, const LLString& extension = LLString()); void playSnapshotAnimAndSound(); @@ -385,7 +388,6 @@ void reset_viewer_state_on_sim(void); extern LLVelocityBar* gVelocityBar; extern LLViewerWindow* gViewerWindow; -extern BOOL gQuietSnapshot; extern LLFrameTimer gMouseIdleTimer; // how long has it been since the mouse last moved? extern LLFrameTimer gAwayTimer; // tracks time before setting the avatar away state to true diff --git a/linden/indra/newview/llvlcomposition.cpp b/linden/indra/newview/llvlcomposition.cpp index 370bf24..4608589 100644 --- a/linden/indra/newview/llvlcomposition.cpp +++ b/linden/indra/newview/llvlcomposition.cpp @@ -2,6 +2,8 @@ * @file llvlcomposition.cpp * @brief Viewer-side representation of a composition layer... * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llvlcomposition.h b/linden/indra/newview/llvlcomposition.h index 964fdfe..65032ca 100644 --- a/linden/indra/newview/llvlcomposition.h +++ b/linden/indra/newview/llvlcomposition.h @@ -2,6 +2,8 @@ * @file llvlcomposition.h * @brief Viewer-side representation of a composition layer... * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVLCOMPOSITION_H diff --git a/linden/indra/newview/llvlmanager.cpp b/linden/indra/newview/llvlmanager.cpp index f4d117d..badd4b4 100644 --- a/linden/indra/newview/llvlmanager.cpp +++ b/linden/indra/newview/llvlmanager.cpp @@ -2,6 +2,8 @@ * @file llvlmanager.cpp * @brief LLVLManager class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llvlmanager.h b/linden/indra/newview/llvlmanager.h index f26c3ce..e004502 100644 --- a/linden/indra/newview/llvlmanager.h +++ b/linden/indra/newview/llvlmanager.h @@ -2,6 +2,8 @@ * @file llvlmanager.h * @brief LLVLManager class definition * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVLMANAGER_H diff --git a/linden/indra/newview/llvoavatar.cpp b/linden/indra/newview/llvoavatar.cpp index 456adfc..41873c7 100644 --- a/linden/indra/newview/llvoavatar.cpp +++ b/linden/indra/newview/llvoavatar.cpp @@ -2,6 +2,8 @@ * @file llvoavatar.cpp * @brief Implementation of LLVOAvatar class which is a derivation fo LLViewerObject * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llvoavatar.h b/linden/indra/newview/llvoavatar.h index 5b92445..18f69a0 100644 --- a/linden/indra/newview/llvoavatar.h +++ b/linden/indra/newview/llvoavatar.h @@ -3,6 +3,8 @@ * @brief Declaration of LLVOAvatar class which is a derivation fo * LLViewerObject * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVOAVATAR_H diff --git a/linden/indra/newview/llvocache.cpp b/linden/indra/newview/llvocache.cpp index 2b3569d..79c7594 100644 --- a/linden/indra/newview/llvocache.cpp +++ b/linden/indra/newview/llvocache.cpp @@ -2,6 +2,8 @@ * @file llvocache.cpp * @brief Cache of objects on the viewer. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llvocache.h b/linden/indra/newview/llvocache.h index 73620c8..809b82a 100644 --- a/linden/indra/newview/llvocache.h +++ b/linden/indra/newview/llvocache.h @@ -2,6 +2,8 @@ * @file llvocache.h * @brief Cache of objects on the viewer. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVOCACHE_H diff --git a/linden/indra/newview/llvoclouds.cpp b/linden/indra/newview/llvoclouds.cpp index be7c1b1..07cfcea 100644 --- a/linden/indra/newview/llvoclouds.cpp +++ b/linden/indra/newview/llvoclouds.cpp @@ -2,6 +2,8 @@ * @file llvoclouds.cpp * @brief Implementation of LLVOClouds class which is a derivation fo LLViewerObject * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llvoclouds.h b/linden/indra/newview/llvoclouds.h index 172d622..500d942 100644 --- a/linden/indra/newview/llvoclouds.h +++ b/linden/indra/newview/llvoclouds.h @@ -2,6 +2,8 @@ * @file llvoclouds.h * @brief Description of LLVOClouds class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVOCLOUDS_H diff --git a/linden/indra/newview/llvograss.cpp b/linden/indra/newview/llvograss.cpp index 4725b33..84fdbff 100644 --- a/linden/indra/newview/llvograss.cpp +++ b/linden/indra/newview/llvograss.cpp @@ -2,6 +2,8 @@ * @file llvograss.cpp * @brief Not a blade, but a clump of grass * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llvograss.h b/linden/indra/newview/llvograss.h index 2349864..f7ce9a4 100644 --- a/linden/indra/newview/llvograss.h +++ b/linden/indra/newview/llvograss.h @@ -2,6 +2,8 @@ * @file llvograss.h * @brief Description of LLVOGrass class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVOGRASS_H diff --git a/linden/indra/newview/llvoground.cpp b/linden/indra/newview/llvoground.cpp index 8c116c1..8f6bc4a 100644 --- a/linden/indra/newview/llvoground.cpp +++ b/linden/indra/newview/llvoground.cpp @@ -2,6 +2,8 @@ * @file llvoground.cpp * @brief LLVOGround class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llvoground.h b/linden/indra/newview/llvoground.h index 48212e5..fd6da91 100644 --- a/linden/indra/newview/llvoground.h +++ b/linden/indra/newview/llvoground.h @@ -2,6 +2,8 @@ * @file llvoground.h * @brief LLVOGround class header file * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVOGROUND_H diff --git a/linden/indra/newview/llvoiceclient.cpp b/linden/indra/newview/llvoiceclient.cpp index 9e1c90a..3a74f16 100644 --- a/linden/indra/newview/llvoiceclient.cpp +++ b/linden/indra/newview/llvoiceclient.cpp @@ -2,6 +2,8 @@ * @file llvoiceclient.cpp * @brief Implementation of LLVoiceClient class which is the interface to the voice client process. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include @@ -1381,7 +1384,7 @@ void LLVoiceClient::stateMachine() sGatewayPID = id; } #endif // LL_WINDOWS - mDaemonHost = LLHost("127.0.0.1", 44124); + mDaemonHost = LLHost(gSavedSettings.getString("VoiceHost").c_str(), gSavedSettings.getU32("VoicePort")); } else { @@ -1394,7 +1397,7 @@ void LLVoiceClient::stateMachine() // To do this, launch the gateway on a nearby host like this: // vivox-gw.exe -p tcp -i 0.0.0.0:44124 // and put that host's IP address here. - mDaemonHost = LLHost("127.0.0.1", 44124); + mDaemonHost = LLHost(gSavedSettings.getString("VoiceHost").c_str(), gSavedSettings.getU32("VoicePort")); } mUpdateTimer.start(); diff --git a/linden/indra/newview/llvoiceclient.h b/linden/indra/newview/llvoiceclient.h index e8c5b33..ed256b6 100644 --- a/linden/indra/newview/llvoiceclient.h +++ b/linden/indra/newview/llvoiceclient.h @@ -2,6 +2,8 @@ * @file llvoiceclient.h * @brief Declaration of LLVoiceClient class which is the interface to the voice client process. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_VOICE_CLIENT_H #define LL_VOICE_CLIENT_H @@ -442,7 +445,7 @@ class LLVoiceClient: public LLSingleton // It initiates the call to the server that gets the parcel channel. void parcelChanged(); - void switchChannel(std::string uri = "", bool spatial = true, bool noReconnect = false, std::string hash = ""); + void switchChannel(std::string uri = std::string(), bool spatial = true, bool noReconnect = false, std::string hash = ""); void joinSession(std::string handle, std::string uri); std::string nameFromAvatar(LLVOAvatar *avatar); @@ -523,3 +526,4 @@ extern LLVoiceClient *gVoiceClient; #endif //LL_VOICE_CLIENT_H + diff --git a/linden/indra/newview/llvoiceremotectrl.cpp b/linden/indra/newview/llvoiceremotectrl.cpp index 720eb17..9878c7d 100644 --- a/linden/indra/newview/llvoiceremotectrl.cpp +++ b/linden/indra/newview/llvoiceremotectrl.cpp @@ -2,6 +2,8 @@ * @file llvoiceremotectrl.cpp * @brief A remote control for voice chat * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llvoiceremotectrl.h b/linden/indra/newview/llvoiceremotectrl.h index 46ed709..7d20598 100644 --- a/linden/indra/newview/llvoiceremotectrl.h +++ b/linden/indra/newview/llvoiceremotectrl.h @@ -2,6 +2,8 @@ * @file llvoiceremotectrl.h * @brief A remote control for voice chat * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVOICEREMOTECTRL_H diff --git a/linden/indra/newview/llvoicevisualizer.cpp b/linden/indra/newview/llvoicevisualizer.cpp index 2c64e46..e667663 100644 --- a/linden/indra/newview/llvoicevisualizer.cpp +++ b/linden/indra/newview/llvoicevisualizer.cpp @@ -2,6 +2,8 @@ * @file llvoicevisualizer.cpp * @brief Draws in-world speaking indicators. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //---------------------------------------------------------------------- diff --git a/linden/indra/newview/llvoicevisualizer.h b/linden/indra/newview/llvoicevisualizer.h index 9cd0465..3543f25 100644 --- a/linden/indra/newview/llvoicevisualizer.h +++ b/linden/indra/newview/llvoicevisualizer.h @@ -2,6 +2,8 @@ * @file llvoicevisualizer.h * @brief Draws in-world speaking indicators. * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ //-------------------------------------------------------------------- diff --git a/linden/indra/newview/llvoinventorylistener.cpp b/linden/indra/newview/llvoinventorylistener.cpp index 1a50682..964e725 100644 --- a/linden/indra/newview/llvoinventorylistener.cpp +++ b/linden/indra/newview/llvoinventorylistener.cpp @@ -2,6 +2,8 @@ * @file llvoinventorylistener.cpp * @brief Interface for classes that wish to receive updates about viewer object inventory * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llvoinventorylistener.h b/linden/indra/newview/llvoinventorylistener.h index a717cb7..6f22575 100644 --- a/linden/indra/newview/llvoinventorylistener.h +++ b/linden/indra/newview/llvoinventorylistener.h @@ -2,6 +2,8 @@ * @file llvoinventorylistener.h * @brief Interface for classes that wish to receive updates about viewer object inventory * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Description of LLVOInventoryListener class, which is an interface diff --git a/linden/indra/newview/llvopartgroup.cpp b/linden/indra/newview/llvopartgroup.cpp index ad65a55..56643e3 100644 --- a/linden/indra/newview/llvopartgroup.cpp +++ b/linden/indra/newview/llvopartgroup.cpp @@ -2,6 +2,8 @@ * @file llvopartgroup.cpp * @brief Group of particle systems * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llvopartgroup.h b/linden/indra/newview/llvopartgroup.h index f301a48..90c8ac4 100644 --- a/linden/indra/newview/llvopartgroup.h +++ b/linden/indra/newview/llvopartgroup.h @@ -2,6 +2,8 @@ * @file llvopartgroup.h * @brief Group of particle systems * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVOPARTGROUP_H diff --git a/linden/indra/newview/llvosky.cpp b/linden/indra/newview/llvosky.cpp index 32a8cac..d3c24a6 100644 --- a/linden/indra/newview/llvosky.cpp +++ b/linden/indra/newview/llvosky.cpp @@ -2,6 +2,8 @@ * @file llvosky.cpp * @brief LLVOSky class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llvosky.h b/linden/indra/newview/llvosky.h index 12980c9..4020114 100644 --- a/linden/indra/newview/llvosky.h +++ b/linden/indra/newview/llvosky.h @@ -2,6 +2,8 @@ * @file llvosky.h * @brief LLVOSky class header file * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVOSKY_H diff --git a/linden/indra/newview/llvostars.cpp b/linden/indra/newview/llvostars.cpp index 5af052d..608a52c 100644 --- a/linden/indra/newview/llvostars.cpp +++ b/linden/indra/newview/llvostars.cpp @@ -2,6 +2,8 @@ * @file llvostars.cpp * @brief LLVOStars class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llvostars.h b/linden/indra/newview/llvostars.h index e2619ce..cccacbe 100644 --- a/linden/indra/newview/llvostars.h +++ b/linden/indra/newview/llvostars.h @@ -2,6 +2,8 @@ * @file llvostars.h * @brief LLVOStars class header file * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVOSTARS_H diff --git a/linden/indra/newview/llvosurfacepatch.cpp b/linden/indra/newview/llvosurfacepatch.cpp index 8089596..05b374e 100644 --- a/linden/indra/newview/llvosurfacepatch.cpp +++ b/linden/indra/newview/llvosurfacepatch.cpp @@ -2,6 +2,8 @@ * @file llvosurfacepatch.cpp * @brief Viewer-object derived "surface patch", which is a piece of terrain * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llvosurfacepatch.h b/linden/indra/newview/llvosurfacepatch.h index e6a6f44..ad2331f 100644 --- a/linden/indra/newview/llvosurfacepatch.h +++ b/linden/indra/newview/llvosurfacepatch.h @@ -2,6 +2,8 @@ * @file llvosurfacepatch.h * @brief Description of LLVOSurfacePatch class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_VOSURFACEPATCH_H diff --git a/linden/indra/newview/llvotextbubble.cpp b/linden/indra/newview/llvotextbubble.cpp index 676f6cb..cd3e4d1 100644 --- a/linden/indra/newview/llvotextbubble.cpp +++ b/linden/indra/newview/llvotextbubble.cpp @@ -2,6 +2,8 @@ * @file llvotextbubble.cpp * @brief Viewer-object text bubble. * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llvotextbubble.h b/linden/indra/newview/llvotextbubble.h index a05b6bc..35d4f97 100644 --- a/linden/indra/newview/llvotextbubble.h +++ b/linden/indra/newview/llvotextbubble.h @@ -2,6 +2,8 @@ * @file llvotextbubble.h * @brief Description of LLVORock class, which a derivation of LLViewerObject * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVOTEXTBUBBLE_H diff --git a/linden/indra/newview/llvotree.cpp b/linden/indra/newview/llvotree.cpp index a752fca..b7c762a 100644 --- a/linden/indra/newview/llvotree.cpp +++ b/linden/indra/newview/llvotree.cpp @@ -2,6 +2,8 @@ * @file llvotree.cpp * @brief LLVOTree class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llvotree.h b/linden/indra/newview/llvotree.h index 6de7c0d..90570f3 100644 --- a/linden/indra/newview/llvotree.h +++ b/linden/indra/newview/llvotree.h @@ -2,6 +2,8 @@ * @file llvotree.h * @brief LLVOTree class header file * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVOTREE_H diff --git a/linden/indra/newview/llvotreenew.h b/linden/indra/newview/llvotreenew.h index 611c341..d8bf5ab 100644 --- a/linden/indra/newview/llvotreenew.h +++ b/linden/indra/newview/llvotreenew.h @@ -2,6 +2,8 @@ * @file llvotreenew.h * @brief LLVOTreeNew class header file * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVOTREENEW_H diff --git a/linden/indra/newview/llvovolume.cpp b/linden/indra/newview/llvovolume.cpp index 4656eda..6867cac 100644 --- a/linden/indra/newview/llvovolume.cpp +++ b/linden/indra/newview/llvovolume.cpp @@ -2,6 +2,8 @@ * @file llvovolume.cpp * @brief LLVOVolume class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // A "volume" is a box, cylinder, sphere, or other primitive shape. diff --git a/linden/indra/newview/llvovolume.h b/linden/indra/newview/llvovolume.h index 5881c04..60700e6 100644 --- a/linden/indra/newview/llvovolume.h +++ b/linden/indra/newview/llvovolume.h @@ -2,6 +2,8 @@ * @file llvovolume.h * @brief LLVOVolume class header file * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLVOVOLUME_H diff --git a/linden/indra/newview/llvowater.cpp b/linden/indra/newview/llvowater.cpp index 0697d82..33095d1 100644 --- a/linden/indra/newview/llvowater.cpp +++ b/linden/indra/newview/llvowater.cpp @@ -2,6 +2,8 @@ * @file llvowater.cpp * @brief LLVOWater class implementation * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llvowater.h b/linden/indra/newview/llvowater.h index 53a0a02..12b5ac0 100644 --- a/linden/indra/newview/llvowater.h +++ b/linden/indra/newview/llvowater.h @@ -2,6 +2,8 @@ * @file llvowater.h * @brief Description of LLVOWater class * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_VOWATER_H diff --git a/linden/indra/newview/llwearable.cpp b/linden/indra/newview/llwearable.cpp index 6db871c..4222e84 100644 --- a/linden/indra/newview/llwearable.cpp +++ b/linden/indra/newview/llwearable.cpp @@ -2,6 +2,8 @@ * @file llwearable.cpp * @brief LLWearable class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llwearable.h b/linden/indra/newview/llwearable.h index 41e9ed2..cd02843 100644 --- a/linden/indra/newview/llwearable.h +++ b/linden/indra/newview/llwearable.h @@ -2,6 +2,8 @@ * @file llwearable.h * @brief LLWearable class header file * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLWEARABLE_H @@ -82,11 +85,11 @@ public: EWearableType getType() const { return mType; } void setType( EWearableType type ) { mType = type; } - void setName( const std::string& name ) { mName = name; } - const std::string& getName() { return mName; } + void setName( const LLString& name ) { mName = name; } + const LLString& getName() { return mName; } - void setDescription( const std::string& desc ) { mDescription = desc; } - const std::string& getDescription() { return mDescription; } + void setDescription( const LLString& desc ) { mDescription = desc; } + const LLString& getDescription() { return mDescription; } void setPermissions( const LLPermissions& p ) { mPermissions = p; } const LLPermissions& getPermissions() { return mPermissions; } diff --git a/linden/indra/newview/llwearablelist.cpp b/linden/indra/newview/llwearablelist.cpp index 8c56727..39a6046 100644 --- a/linden/indra/newview/llwearablelist.cpp +++ b/linden/indra/newview/llwearablelist.cpp @@ -2,6 +2,8 @@ * @file llwearablelist.cpp * @brief LLWearableList class implementation * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -129,7 +132,7 @@ void LLWearableList::processGetAssetReply( const char* filename, const LLAssetID else { LLString::format_map_t args; - // XUI:translate + // *TODO:translate args["[TYPE]"] = LLAssetType::lookupHumanReadable(data->mAssetType); if (data->mName.empty()) { @@ -167,7 +170,7 @@ void LLWearableList::processGetAssetReply( const char* filename, const LLAssetID case LL_ERR_ASSET_REQUEST_NOT_IN_DATABASE: { LLString::format_map_t args; - // XUI:translate + // *TODO:translate args["[TYPE]"] = LLAssetType::lookupHumanReadable(data->mAssetType); if (data->mName.empty()) { diff --git a/linden/indra/newview/llwearablelist.h b/linden/indra/newview/llwearablelist.h index 3627685..303fcb7 100644 --- a/linden/indra/newview/llwearablelist.h +++ b/linden/indra/newview/llwearablelist.h @@ -2,6 +2,8 @@ * @file llwearablelist.h * @brief LLWearableList class header file * + * $LicenseInfo:firstyear=2002&license=viewergpl$ + * * Copyright (c) 2002-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLWEARABLELIST_H @@ -54,7 +57,7 @@ public: LLWearable* createLegacyWearableFromAvatar( EWearableType type ); LLWearable* createWearableMatchedToInventoryItem( LLWearable* old_wearable, LLViewerInventoryItem* item ); - LLWearable* createCopyFromAvatar( LLWearable* old_wearable, const std::string& new_name = "" ); + LLWearable* createCopyFromAvatar( LLWearable* old_wearable, const std::string& new_name = std::string() ); LLWearable* createCopy( LLWearable* old_wearable ); LLWearable* createNewWearable( EWearableType type ); diff --git a/linden/indra/newview/llweb.cpp b/linden/indra/newview/llweb.cpp index d15d4c4..f908cd2 100644 --- a/linden/indra/newview/llweb.cpp +++ b/linden/indra/newview/llweb.cpp @@ -3,6 +3,8 @@ * @brief Functions dealing with web browsers * @author James Cook * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llweb.h b/linden/indra/newview/llweb.h index 8bc402c..b339f2d 100644 --- a/linden/indra/newview/llweb.h +++ b/linden/indra/newview/llweb.h @@ -3,6 +3,8 @@ * @brief Functions dealing with web browsers * @author James Cook * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -25,6 +27,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLWEB_H diff --git a/linden/indra/newview/llwebbrowserctrl.cpp b/linden/indra/newview/llwebbrowserctrl.cpp index 26e5076..5de0d43 100644 --- a/linden/indra/newview/llwebbrowserctrl.cpp +++ b/linden/indra/newview/llwebbrowserctrl.cpp @@ -2,6 +2,8 @@ * @file llwebbrowserctrl.cpp * @brief Web browser UI control * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -34,6 +37,7 @@ #include "llviewborder.h" #include "llviewerwindow.h" #include "llfloaterworldmap.h" +#include "llurldispatcher.h" #include "llfocusmgr.h" #include "llweb.h" #include "viewer.h" @@ -521,54 +525,12 @@ void LLWebBrowserCtrl::onClickLinkHref( const EventType& eventIn ) // virtual void LLWebBrowserCtrl::onClickLinkSecondLife( const EventType& eventIn ) { - const std::string protocol( "secondlife://" ); - - if ( eventIn.getStringValue().length() ) - { - if ( LLString::compareInsensitive( eventIn.getStringValue().substr( 0, protocol.length() ).c_str(), protocol.c_str() ) == 0 ) - { - if ( mOpenSecondLifeLinksInMap ) - { - openMapAtlocation( eventIn.getStringValue() ); - }; - - // chain this event on to observers of an instance of LLWebBrowserCtrl - LLWebBrowserCtrlEvent event( eventIn.getStringValue() ); - mEventEmitter.update( &LLWebBrowserCtrlObserver::onClickLinkSecondLife, event ); - }; - }; -} - -//////////////////////////////////////////////////////////////////////////////// -// virtual -void LLWebBrowserCtrl::openMapAtlocation( std::string second_life_url ) -{ - // parse out sim name and coordinates - LLURLSimString::setString( second_life_url ); - LLURLSimString::parse(); - - // if there is a world map - if ( gFloaterWorldMap ) - { - #if ! LL_RELEASE_FOR_DOWNLOAD - llinfos << "MOZ> opening map to " << LLURLSimString::sInstance.mSimName.c_str() << " at " << LLURLSimString::sInstance.mX << "," << LLURLSimString::sInstance.mY << "," << LLURLSimString::sInstance.mZ << llendl; - #endif - - // mark where the destination is - gFloaterWorldMap->trackURL( LLURLSimString::sInstance.mSimName.c_str(), - LLURLSimString::sInstance.mX, - LLURLSimString::sInstance.mY, - LLURLSimString::sInstance.mZ ); + std::string url = eventIn.getStringValue(); + LLURLDispatcher::dispatch(url); - // display map - LLFloaterWorldMap::show( NULL, TRUE ); - } - else - // if there is no world map, assume we're on the login page.. (this might be bad but I don't see a way to tell if you're at login or not) - { - // refresh the login page and force the location combo box to be visible - LLPanelLogin::refreshLocation( true ); - }; + // chain this event on to observers of an instance of LLWebBrowserCtrl + LLWebBrowserCtrlEvent event( eventIn.getStringValue() ); + mEventEmitter.update( &LLWebBrowserCtrlObserver::onClickLinkSecondLife, event ); } //////////////////////////////////////////////////////////////////////////////// diff --git a/linden/indra/newview/llwebbrowserctrl.h b/linden/indra/newview/llwebbrowserctrl.h index 785f28b..892345a 100644 --- a/linden/indra/newview/llwebbrowserctrl.h +++ b/linden/indra/newview/llwebbrowserctrl.h @@ -2,6 +2,8 @@ * @file llwebbrowserctrl.h * @brief Web browser UI control * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLWEBBROWSERCTRL_H @@ -199,9 +202,6 @@ class LLWebBrowserCtrl : void setIgnoreUIScale(bool ignore) { mIgnoreUIScale = ignore; } bool getIgnoreUIScale() { return mIgnoreUIScale; } - // map releated control (this should be moved eventually) - void openMapAtlocation( std::string second_life_url ); - void setAlwaysRefresh(bool refresh) { mAlwaysRefresh = refresh; } bool getAlwaysRefresh() { return mAlwaysRefresh; } diff --git a/linden/indra/newview/llwind.cpp b/linden/indra/newview/llwind.cpp index 247e28c..b04299b 100644 --- a/linden/indra/newview/llwind.cpp +++ b/linden/indra/newview/llwind.cpp @@ -2,6 +2,8 @@ * @file llwind.cpp * @brief LLWind class implementation * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Wind is a lattice. It is computed on the simulator, and transmitted to the viewer. diff --git a/linden/indra/newview/llwind.h b/linden/indra/newview/llwind.h index af7a8bb..ed8d19c 100644 --- a/linden/indra/newview/llwind.h +++ b/linden/indra/newview/llwind.h @@ -2,6 +2,8 @@ * @file llwind.h * @brief LLWind class header file * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLWIND_H diff --git a/linden/indra/newview/llwindebug.cpp b/linden/indra/newview/llwindebug.cpp index 7433984..b65262c 100644 --- a/linden/indra/newview/llwindebug.cpp +++ b/linden/indra/newview/llwindebug.cpp @@ -2,6 +2,8 @@ * @file llwindebug.cpp * @brief Windows debugging functions * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llwindebug.h b/linden/indra/newview/llwindebug.h index 50e168c..bb1f11d 100644 --- a/linden/indra/newview/llwindebug.h +++ b/linden/indra/newview/llwindebug.h @@ -2,6 +2,8 @@ * @file llwindebug.h * @brief LLWinDebug class header file * + * $LicenseInfo:firstyear=2004&license=viewergpl$ + * * Copyright (c) 2004-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLWINDEBUG_H diff --git a/linden/indra/newview/llworld.cpp b/linden/indra/newview/llworld.cpp index 3c314cd..dd3223c 100644 --- a/linden/indra/newview/llworld.cpp +++ b/linden/indra/newview/llworld.cpp @@ -2,6 +2,8 @@ * @file llworld.cpp * @brief Initial test structure to organize viewer regions * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llworld.h b/linden/indra/newview/llworld.h index d2482ac..91685cd 100644 --- a/linden/indra/newview/llworld.h +++ b/linden/indra/newview/llworld.h @@ -2,6 +2,8 @@ * @file llworld.h * @brief Initial test structure to organize viewer regions * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLWORLD_H diff --git a/linden/indra/newview/llworldmap.cpp b/linden/indra/newview/llworldmap.cpp index 82e6b6e..16a8be7 100644 --- a/linden/indra/newview/llworldmap.cpp +++ b/linden/indra/newview/llworldmap.cpp @@ -2,6 +2,8 @@ * @file llworldmap.cpp * @brief Underlying data representation for map of the world * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llworldmap.h b/linden/indra/newview/llworldmap.h index 5aaff63..5b2b977 100644 --- a/linden/indra/newview/llworldmap.h +++ b/linden/indra/newview/llworldmap.h @@ -2,6 +2,8 @@ * @file llworldmap.h * @brief Underlying data storage for the map of the entire world. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_LLWORLDMAP_H diff --git a/linden/indra/newview/llworldmapview.cpp b/linden/indra/newview/llworldmapview.cpp index 0c98305..08d8aad 100644 --- a/linden/indra/newview/llworldmapview.cpp +++ b/linden/indra/newview/llworldmapview.cpp @@ -2,6 +2,8 @@ * @file llworldmapview.cpp * @brief LLWorldMapView class implementation * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -52,6 +55,7 @@ #include "llviewercamera.h" #include "llviewerimage.h" #include "llviewerimagelist.h" +#include "llviewermenu.h" #include "llviewerparceloverlay.h" #include "llviewerregion.h" #include "llviewerwindow.h" @@ -69,6 +73,8 @@ BOOL LLWorldMapView::sHandledLastClick = FALSE; LLPointer LLWorldMapView::sAvatarYouSmallImage = NULL; LLPointer LLWorldMapView::sAvatarSmallImage = NULL; LLPointer LLWorldMapView::sAvatarLargeImage = NULL; +LLPointer LLWorldMapView::sAvatarAboveImage = NULL; +LLPointer LLWorldMapView::sAvatarBelowImage = NULL; LLPointer LLWorldMapView::sTelehubImage = NULL; LLPointer LLWorldMapView::sInfohubImage = NULL; @@ -107,6 +113,12 @@ void LLWorldMapView::initClass() image_id.set( gViewerArt.getString("map_avatar_16.tga") ); sAvatarLargeImage = gImageList.getImage( image_id, MIPMAP_FALSE, TRUE); + image_id.set( gViewerArt.getString("map_avatar_above_8.tga") ); + sAvatarAboveImage = gImageList.getImage( image_id, MIPMAP_FALSE, TRUE); + + image_id.set( gViewerArt.getString("map_avatar_below_8.tga") ); + sAvatarBelowImage = gImageList.getImage( image_id, MIPMAP_FALSE, TRUE); + image_id.set( gViewerArt.getString("map_home.tga") ); sHomeImage = gImageList.getImage(image_id, MIPMAP_FALSE, TRUE); @@ -147,6 +159,8 @@ void LLWorldMapView::cleanupClass() sAvatarYouSmallImage = NULL; sAvatarSmallImage = NULL; sAvatarLargeImage = NULL; + sAvatarAboveImage = NULL; + sAvatarBelowImage = NULL; sTelehubImage = NULL; sInfohubImage = NULL; sHomeImage = NULL; @@ -274,18 +288,16 @@ void LLWorldMapView::setPan( S32 x, S32 y, BOOL snap ) /////////////////////////////////////////////////////////////////////////////////// +// HELPERS -// dumb helper function BOOL is_agent_in_region(LLViewerRegion* region, LLSimInfo* info) { - if((region && info) - && (info->mName == region->getName())) - { - return TRUE; - } - return FALSE; + return ((region && info) && (info->mName == region->getName())); } + +/////////////////////////////////////////////////////////////////////////////////// + void LLWorldMapView::draw() { if (!getVisible() || !gWorldPointer) @@ -303,9 +315,6 @@ void LLWorldMapView::draw() sPanX = lerp(sPanX, sTargetPanX, LLCriticalDamp::getInterpolant(0.1f)); sPanY = lerp(sPanY, sTargetPanY, LLCriticalDamp::getInterpolant(0.1f)); - LLVector3d pos_global; - LLVector3 pos_map; - const S32 width = mRect.getWidth(); const S32 height = mRect.getHeight(); const S32 half_width = width / 2; @@ -685,56 +694,24 @@ void LLWorldMapView::draw() glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); // Infohubs - // Draw under avatar so you can find yourself. if (gSavedSettings.getBOOL("MapShowInfohubs")) //(gMapScale >= sThresholdB) { - S32 infohub_icon_size = (S32)sInfohubImage->getWidth(); - for (U32 infohub=0; infohubmInfohubs.size(); ++infohub) - { - LLItemInfo *infohub_info = &gWorldMap->mInfohubs[infohub]; - - pos_map = globalPosToView(infohub_info->mPosGlobal); - gl_draw_image(llround(pos_map.mV[VX])-infohub_icon_size/2, - llround(pos_map.mV[VY])-infohub_icon_size/2, - sInfohubImage, - LLColor4::white); - } + drawGenericItems(gWorldMap->mInfohubs, sInfohubImage); } // Telehubs - // Draw under avatar so you can find yourself. if (gSavedSettings.getBOOL("MapShowTelehubs")) //(gMapScale >= sThresholdB) { - S32 telehub_icon_size = (S32)sTelehubImage->getWidth(); - for (U32 telehub=0; telehubmTelehubs.size(); ++telehub) - { - LLItemInfo *telehub_info = &gWorldMap->mTelehubs[telehub]; - - pos_map = globalPosToView(telehub_info->mPosGlobal); - gl_draw_image(llround(pos_map.mV[VX])-telehub_icon_size/2, - llround(pos_map.mV[VY])-telehub_icon_size/2, - sTelehubImage, - LLColor4::white); - } + drawGenericItems(gWorldMap->mTelehubs, sTelehubImage); } - // Home - // Always Draw - if (1) //(gMapScale >= sThresholdB) + // Home Sweet Home + LLVector3d home; + if (gAgent.getHomePosGlobal(&home)) { - S32 home_icon_size = (S32)sHomeImage->getWidth(); - if (gAgent.getHomePosGlobal(&pos_global)) - { - pos_map = globalPosToView(pos_global); - gl_draw_image(llround(pos_map.mV[VX])-home_icon_size/2, - llround(pos_map.mV[VY])-home_icon_size/2, - sHomeImage, - LLColor4::white); - } + drawImage(home, sHomeImage); } - // Draw all these under the avatar, so you can find yourself - if (gSavedSettings.getBOOL("MapShowLandForSale")) { drawGenericItems(gWorldMap->mLandForSale, sForSaleImage); @@ -755,15 +732,11 @@ void LLWorldMapView::draw() drawEvents(); } - // Your avatar. - // Draw avatar position, always, and underneath other avatars - pos_global = gAgent.getPositionGlobal(); - pos_map = globalPosToView(pos_global); - gl_draw_image(llround(pos_map.mV[VX])-8, - llround(pos_map.mV[VY])-8, - sAvatarLargeImage, - LLColor4::white); + // Now draw your avatar after all that other stuff. + LLVector3d pos_global = gAgent.getPositionGlobal(); + drawImage(pos_global, sAvatarLargeImage); + LLVector3 pos_map = globalPosToView(pos_global); if (!pointInView(llround(pos_map.mV[VX]), llround(pos_map.mV[VY]))) { drawTracking(pos_global, @@ -774,17 +747,16 @@ void LLWorldMapView::draw() llround(LLFontGL::sSansSerifSmall->getLineHeight())); // offset vertically by one line, to avoid overlap with target tracking } + // Show your viewing angle drawFrustum(); // Draw icons for the avatars in each region. - // Draw after avatar so you can see nearby people. + // Drawn after your avatar so you can see nearby people. if (gSavedSettings.getBOOL("MapShowPeople")) { drawAgents(); } - //----------------------------------------------------------------------- - // Always draw tracking information LLTracker::ETrackingStatus tracking_status = LLTracker::getTrackingStatus(); if ( LLTracker::TRACKING_AVATAR == tracking_status ) @@ -828,7 +800,8 @@ void LLWorldMapView::draw() LLView::draw(); updateVisibleBlocks(); -} +} // end draw() + //virtual void LLWorldMapView::setVisible(BOOL visible) @@ -868,29 +841,40 @@ void LLWorldMapView::drawGenericItems(const LLWorldMap::item_info_list_t& items, LLWorldMap::item_info_list_t::const_iterator e; for (e = items.begin(); e != items.end(); ++e) { - const LLItemInfo& info = *e; - - drawGenericItem(info, image); + drawGenericItem(*e, image); } } void LLWorldMapView::drawGenericItem(const LLItemInfo& item, LLPointer image) { - S32 half_width = image->getWidth()/2; - S32 half_height = image->getHeight()/2; - - LLVector3 pos_map = globalPosToView( item.mPosGlobal ); - gl_draw_image(llround(pos_map.mV[VX]) - half_width, - llround(pos_map.mV[VY]) - half_height, - image, - LLColor4::white); + drawImage(item.mPosGlobal, image); } -void LLWorldMapView::drawAgents() + +void LLWorldMapView::drawImage(const LLVector3d& global_pos, LLPointer image, const LLColor4& color) { - //S32 half_width = sPopularImage->getWidth()/2; - //S32 half_height = sPopularImage->getHeight()/2; + LLVector3 pos_map = globalPosToView( global_pos ); + gl_draw_image(llround(pos_map.mV[VX] - image->getWidth() /2.f), + llround(pos_map.mV[VY] - image->getHeight()/2.f), + image, + color); +} +void LLWorldMapView::drawImageStack(const LLVector3d& global_pos, LLPointer image, U32 count, F32 offset, const LLColor4& color) +{ + LLVector3 pos_map = globalPosToView( global_pos ); + for(U32 i=0; igetWidth() /2.f), + llround(pos_map.mV[VY] - image->getHeight()/2.f + i*offset), + image, + color); + } +} + + +void LLWorldMapView::drawAgents() +{ F32 agents_scale = (gMapScale * 0.9f) / 256.f; for (handle_list_t::iterator iter = mVisibleRegions.begin(); iter != mVisibleRegions.end(); ++iter) @@ -901,32 +885,20 @@ void LLWorldMapView::drawAgents() { continue; } - LLWorldMap::agent_list_map_t::iterator countsiter = gWorldMap->mAgentLocationsMap.find(handle); - if (siminfo && siminfo->mShowAgentLocations && countsiter != gWorldMap->mAgentLocationsMap.end()) + LLWorldMap::agent_list_map_t::iterator counts_iter = gWorldMap->mAgentLocationsMap.find(handle); + if (siminfo && siminfo->mShowAgentLocations && counts_iter != gWorldMap->mAgentLocationsMap.end()) { - // Show Individual agents - LLWorldMap::item_info_list_t& agentcounts = countsiter->second; + // Show Individual agents (or little stacks where real agents are) + LLWorldMap::item_info_list_t& agentcounts = counts_iter->second; S32 sim_agent_count = 0; for (LLWorldMap::item_info_list_t::iterator iter = agentcounts.begin(); iter != agentcounts.end(); ++iter) { const LLItemInfo& info = *iter; - LLVector3 pos_map = globalPosToView( info.mPosGlobal ); S32 agent_count = info.mExtra; - if (agent_count > 0) - { - sim_agent_count += agent_count; - F32 y = 0; - for (S32 cur_agent = 0; cur_agent < agent_count; cur_agent++) - { - gl_draw_image(llround(pos_map.mV[VX]) - 4, - llround(pos_map.mV[VY] + y) - 4, - sAvatarSmallImage, - LLColor4::white ); - // move up a bit - y += 3.f; - } - } + // Here's how we'd choose the color if info.mID were available but it's not being sent: + //LLColor4 color = (agent_count == 1 && is_agent_friend(info.mID)) ? gFriendMapColor : gAvatarMapColor; + drawImageStack(info.mPosGlobal, sAvatarSmallImage, agent_count, 3.f, gAvatarMapColor); } gWorldMap->mNumAgents[handle] = sim_agent_count; // override mNumAgents for this sim } @@ -936,24 +908,12 @@ void LLWorldMapView::drawAgents() S32 num_agents = gWorldMap->mNumAgents[handle]; if (num_agents > 0) { - LLVector3d region_pos = from_region_handle(handle); - region_pos[VX] += REGION_WIDTH_METERS * .5f; - region_pos[VY] += REGION_WIDTH_METERS * .5f; - LLVector3 pos_map = globalPosToView(region_pos); + LLVector3d region_center = from_region_handle(handle); + region_center[VX] += REGION_WIDTH_METERS / 2; + region_center[VY] += REGION_WIDTH_METERS / 2; // Reduce the stack size as you zoom out - always display at lease one agent where there is one or more S32 agent_count = (S32)(((num_agents-1) * agents_scale + (num_agents-1) * 0.1f)+.1f) + 1; - S32 y = 0; - S32 cur_agent; - for (cur_agent = 0; cur_agent < agent_count; cur_agent++) - { - gl_draw_image( - llround(pos_map.mV[VX]) - 4, - llround(pos_map.mV[VY]) + y - 4, - sAvatarSmallImage, - LLColor4::white ); - // move up a bit - y += 3; - } + drawImageStack(region_center, sAvatarSmallImage, agent_count, 3.f, gAvatarMapColor); } } } @@ -962,95 +922,46 @@ void LLWorldMapView::drawAgents() void LLWorldMapView::drawEvents() { - BOOL show_mature = gSavedSettings.getBOOL("ShowMatureEvents"); - - // Non-selected events - // Draw under avatar so you can find yourself. - LLWorldMap::item_info_list_t::const_iterator e; - for (e = gWorldMap->mPGEvents.begin(); e != gWorldMap->mPGEvents.end(); ++e) - { - const LLItemInfo& event = *e; - - // Draw, but without relative-Z icons - if (!event.mSelected) - { - LLVector3 pos_map = globalPosToView( event.mPosGlobal ); - gl_draw_image(llround(pos_map.mV[VX]) - sEventImage->getWidth()/2, - llround(pos_map.mV[VY]) - sEventImage->getHeight()/2, - sEventImage, - LLColor4::white); - } - } - if (show_mature) - { - for (e = gWorldMap->mMatureEvents.begin(); e != gWorldMap->mMatureEvents.end(); ++e) - { - const LLItemInfo& event = *e; - - // Draw, but without relative-Z icons - if (!event.mSelected) - { - LLVector3 pos_map = globalPosToView( event.mPosGlobal ); - gl_draw_image(llround(pos_map.mV[VX]) - sEventMatureImage->getWidth()/2, - llround(pos_map.mV[VY]) - sEventMatureImage->getHeight()/2, - sEventMatureImage, - LLColor4::white); - } - } - } - - // Selected events - // Draw under avatar so you can find yourself. - for (e = gWorldMap->mPGEvents.begin(); e != gWorldMap->mPGEvents.end(); ++e) - { - const LLItemInfo& event = *e; - - // Draw, but without relative-Z icons - if (event.mSelected) - { - LLVector3 pos_map = globalPosToView( event.mPosGlobal ); - gl_draw_image(llround(pos_map.mV[VX]) - sEventImage->getWidth()/2, - llround(pos_map.mV[VY]) - sEventImage->getHeight()/2, - sEventImage, - LLColor4::white); - - //drawIconName( - // pos_map.mV[VX], - // pos_map.mV[VY], - // gEventColor, - // event.mToolTip.c_str(), - // event.mName.c_str() ); - } - } - if (show_mature) - { - for (e = gWorldMap->mMatureEvents.begin(); e != gWorldMap->mMatureEvents.end(); ++e) - { - const LLItemInfo& event = *e; - - // Draw, but without relative-Z icons - if (event.mSelected) - { - LLVector3 pos_map = globalPosToView( event.mPosGlobal ); - gl_draw_image(llround(pos_map.mV[VX]) - sEventMatureImage->getWidth()/2, - llround(pos_map.mV[VY]) - sEventMatureImage->getHeight()/2, - sEventMatureImage, - LLColor4::white); - - //drawIconName( - // pos_map.mV[VX], - // pos_map.mV[VY], - // gEventColor, - // event.mToolTip.c_str(), - // event.mName.c_str() ); - } - } - } -} - -void LLWorldMapView::drawDots() -{ - + BOOL show_mature = gSavedSettings.getBOOL("ShowMatureEvents"); + + // First the non-selected events + LLWorldMap::item_info_list_t::const_iterator e; + for (e = gWorldMap->mPGEvents.begin(); e != gWorldMap->mPGEvents.end(); ++e) + { + if (!e->mSelected) + { + drawGenericItem(*e, sEventImage); + } + } + if (show_mature) + { + for (e = gWorldMap->mMatureEvents.begin(); e != gWorldMap->mMatureEvents.end(); ++e) + { + if (!e->mSelected) + { + drawGenericItem(*e, sEventMatureImage); + } + } + } + + // Then the selected events + for (e = gWorldMap->mPGEvents.begin(); e != gWorldMap->mPGEvents.end(); ++e) + { + if (e->mSelected) + { + drawGenericItem(*e, sEventImage); + } + } + if (show_mature) + { + for (e = gWorldMap->mMatureEvents.begin(); e != gWorldMap->mMatureEvents.end(); ++e) + { + if (e->mSelected) + { + drawGenericItem(*e, sEventMatureImage); + } + } + } } @@ -1143,11 +1054,7 @@ void LLWorldMapView::drawTracking(const LLVector3d& pos_global, const LLColor4& } else { - // Draw, but without relative Z - gl_draw_image(x - sTrackCircleImage->getWidth()/2, - y - sTrackCircleImage->getHeight()/2, - sTrackCircleImage, - color); + drawImage(pos_global, sTrackCircleImage, color); } // clamp text position to on-screen @@ -1271,50 +1178,38 @@ BOOL LLWorldMapView::handleToolTip( S32 x, S32 y, LLString& msg, LLRect* sticky_ // Pass relative Z of 0 to draw at same level. // static -void LLWorldMapView::drawAvatar(F32 x_pixels, - F32 y_pixels, - const LLColor4& color, - F32 relative_z, - F32 dot_radius) -{ - F32 left = x_pixels - dot_radius; - F32 right = x_pixels + dot_radius; - F32 center = (left + right) * 0.5f; - F32 top = y_pixels + dot_radius; - F32 bottom = y_pixels - dot_radius; - +static void drawDot(F32 x_pixels, F32 y_pixels, + const LLColor4& color, + F32 relative_z, + F32 dot_radius, + LLPointer dot_image) +{ const F32 HEIGHT_THRESHOLD = 7.f; - if (relative_z > HEIGHT_THRESHOLD) - { - LLGLSNoTexture gls_no_texture; - glColor4fv( color.mV ); - LLUI::setLineWidth(1.5f); - glBegin( GL_LINES ); - glVertex2f(left, top); - glVertex2f(right, top); - glVertex2f(center, top); - glVertex2f(center, bottom); - glEnd(); - LLUI::setLineWidth(1.0f); - } - else if (relative_z > -HEIGHT_THRESHOLD) + if(-HEIGHT_THRESHOLD <= relative_z && relative_z <= HEIGHT_THRESHOLD) { - gl_draw_image( llround(x_pixels) - sAvatarSmallImage->getWidth()/2, - llround(y_pixels) - sAvatarSmallImage->getHeight()/2, - sAvatarSmallImage, + gl_draw_image( llround(x_pixels) - dot_image->getWidth()/2, + llround(y_pixels) - dot_image->getHeight()/2, + dot_image, color); } else { + F32 left = x_pixels - dot_radius; + F32 right = x_pixels + dot_radius; + F32 center = (left + right) * 0.5f; + F32 top = y_pixels + dot_radius; + F32 bottom = y_pixels - dot_radius; + LLGLSNoTexture gls_no_texture; glColor4fv( color.mV ); LLUI::setLineWidth(1.5f); + F32 h_bar = relative_z > HEIGHT_THRESHOLD ? top : bottom; // horizontal bar Y glBegin( GL_LINES ); + glVertex2f(left, h_bar); + glVertex2f(right, h_bar); glVertex2f(center, top); glVertex2f(center, bottom); - glVertex2f(left, bottom); - glVertex2f(right, bottom); glEnd(); LLUI::setLineWidth(1.0f); } @@ -1322,53 +1217,37 @@ void LLWorldMapView::drawAvatar(F32 x_pixels, // Pass relative Z of 0 to draw at same level. // static +void LLWorldMapView::drawAvatar(F32 x_pixels, + F32 y_pixels, + const LLColor4& color, + F32 relative_z, + F32 dot_radius) +{ + const F32 HEIGHT_THRESHOLD = 7.f; + LLViewerImage* dot_image = sAvatarSmallImage; + if(relative_z < -HEIGHT_THRESHOLD) + { + dot_image = sAvatarBelowImage; + } + else if(relative_z > HEIGHT_THRESHOLD) + { + dot_image = sAvatarAboveImage; + } + gl_draw_image( + llround(x_pixels) - dot_image->getWidth()/2, + llround(y_pixels) - dot_image->getHeight()/2, + dot_image, color); +} + +// Pass relative Z of 0 to draw at same level. +// static void LLWorldMapView::drawTrackingDot( F32 x_pixels, F32 y_pixels, const LLColor4& color, F32 relative_z, F32 dot_radius) -{ - F32 left = x_pixels - dot_radius; - F32 right = x_pixels + dot_radius; - F32 center = (left + right) * 0.5f; - F32 top = y_pixels + dot_radius; - F32 bottom = y_pixels - dot_radius; - - const F32 HEIGHT_THRESHOLD = 7.f; - - if (relative_z > HEIGHT_THRESHOLD) - { - LLGLSNoTexture gls_no_texture; - glColor4fv( color.mV ); - LLUI::setLineWidth(1.5f); - glBegin( GL_LINES ); - glVertex2f(left, top); - glVertex2f(right, top); - glVertex2f(center, top); - glVertex2f(center, bottom); - glEnd(); - LLUI::setLineWidth(1.0f); - } - else if (relative_z > -HEIGHT_THRESHOLD) - { - gl_draw_image( llround(x_pixels) - sAvatarSmallImage->getWidth()/2, - llround(y_pixels) - sAvatarSmallImage->getHeight()/2, - sTrackCircleImage, - color); - } - else - { - LLGLSNoTexture gls_no_texture; - glColor4fv( color.mV ); - LLUI::setLineWidth(1.5f); - glBegin( GL_LINES ); - glVertex2f(center, top); - glVertex2f(center, bottom); - glVertex2f(left, bottom); - glVertex2f(right, bottom); - glEnd(); - LLUI::setLineWidth(1.0f); - } +{ + drawDot(x_pixels, y_pixels, color, relative_z, dot_radius, sTrackCircleImage); } diff --git a/linden/indra/newview/llworldmapview.h b/linden/indra/newview/llworldmapview.h index 7eeb554..28ffb42 100644 --- a/linden/indra/newview/llworldmapview.h +++ b/linden/indra/newview/llworldmapview.h @@ -2,6 +2,8 @@ * @file llworldmapview.h * @brief LLWorldMapView class header file * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // Global map of the world. @@ -89,9 +92,10 @@ public: virtual void draw(); void drawGenericItems(const LLWorldMap::item_info_list_t& items, LLPointer image); void drawGenericItem(const LLItemInfo& item, LLPointer image); + void drawImage(const LLVector3d& global_pos, LLPointer image, const LLColor4& color = LLColor4::white); + void drawImageStack(const LLVector3d& global_pos, LLPointer image, U32 count, F32 offset, const LLColor4& color); void drawAgents(); void drawEvents(); - void drawDots(); void drawFrustum(); static void cleanupTextures(); @@ -100,7 +104,7 @@ public: // the view area. void drawTracking( const LLVector3d& pos_global, const LLColor4& color, - BOOL draw_arrow = TRUE, LLString label = "", LLString tooltip = "", S32 vert_offset = 0); + BOOL draw_arrow = TRUE, LLString label = LLString(), LLString tooltip = "", S32 vert_offset = 0); static void drawTrackingArrow(const LLRect& view_rect, S32 x, S32 y, const LLColor4& color, S32 arrow_size = DEFAULT_TRACKING_ARROW_SIZE); @@ -142,6 +146,8 @@ public: static LLPointer sAvatarYouSmallImage; static LLPointer sAvatarSmallImage; static LLPointer sAvatarLargeImage; + static LLPointer sAvatarAboveImage; + static LLPointer sAvatarBelowImage; static LLPointer sTelehubImage; static LLPointer sInfohubImage; static LLPointer sHomeImage; diff --git a/linden/indra/newview/llxmlrpctransaction.cpp b/linden/indra/newview/llxmlrpctransaction.cpp index 55074a4..905e35c 100644 --- a/linden/indra/newview/llxmlrpctransaction.cpp +++ b/linden/indra/newview/llxmlrpctransaction.cpp @@ -2,6 +2,8 @@ * @file llxmlrpctransaction.cpp * @brief LLXMLRPCTransaction and related class implementations * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/llxmlrpctransaction.h b/linden/indra/newview/llxmlrpctransaction.h index 460cfbe..0fc89e7 100644 --- a/linden/indra/newview/llxmlrpctransaction.h +++ b/linden/indra/newview/llxmlrpctransaction.h @@ -2,6 +2,8 @@ * @file llxmlrpctransaction.h * @brief LLXMLRPCTransaction and related class header file * + * $LicenseInfo:firstyear=2006&license=viewergpl$ + * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LLXMLRPCTRANSACTION_H diff --git a/linden/indra/newview/macmain.h b/linden/indra/newview/macmain.h index 49e4b3e..011926c 100644 --- a/linden/indra/newview/macmain.h +++ b/linden/indra/newview/macmain.h @@ -2,6 +2,8 @@ * @file macmain.h * @brief Main Mac viewer defines * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /* main.h */ diff --git a/linden/indra/newview/macutil_Prefix.h b/linden/indra/newview/macutil_Prefix.h index ac1cd1b..f8050c8 100644 --- a/linden/indra/newview/macutil_Prefix.h +++ b/linden/indra/newview/macutil_Prefix.h @@ -2,6 +2,8 @@ * @file macutil_Prefix.h * @brief Precompiled prefix file * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ /* diff --git a/linden/indra/newview/macview.xcodeproj/project.pbxproj b/linden/indra/newview/macview.xcodeproj/project.pbxproj index 0594224..4292995 100644 --- a/linden/indra/newview/macview.xcodeproj/project.pbxproj +++ b/linden/indra/newview/macview.xcodeproj/project.pbxproj @@ -37,6 +37,7 @@ 1A47B8E00860FDF100F73746 /* llpanelweb.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 1A47B8DE0860FDF100F73746 /* llpanelweb.cpp */; }; 1A5104450ABF5B5A00520F6D /* llnotecard.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 1A5104440ABF5B5A00520F6D /* llnotecard.cpp */; }; 1A5104570ABF60A800520F6D /* llviewerassetstorage.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 1A5104560ABF60A800520F6D /* llviewerassetstorage.cpp */; }; + 1A57CD2C0C9EFE9900B6EB24 /* llfloaterlagmeter.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 1A57CD2B0C9EFE9900B6EB24 /* llfloaterlagmeter.cpp */; }; 1A5B3B550A70147000A90391 /* llfloaterbump.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 1A5B3B540A70147000A90391 /* llfloaterbump.cpp */; }; 1A61A7F00A5ED446009FE3D2 /* llfloateravatarpicker.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 1A61A7EF0A5ED446009FE3D2 /* llfloateravatarpicker.cpp */; }; 1A758C920A436FCA00589675 /* llagentdata.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 1A758C910A436FCA00589675 /* llagentdata.cpp */; }; @@ -52,6 +53,9 @@ 1A97C4560B8BCF9C00331A24 /* llliveappconfig.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 1A97C4540B8BCF9C00331A24 /* llliveappconfig.cpp */; }; 1A9897E90B98E2F4005C45D7 /* llbase32.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 1A9897E80B98E2F4005C45D7 /* llbase32.cpp */; }; 1A9EC237083EA0100023D510 /* llfloatereditui.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 1A9EC236083EA0100023D510 /* llfloatereditui.cpp */; }; + 1AD394100CAB000F004BA76A /* llurlsimstring.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 1AD3940E0CAB000F004BA76A /* llurlsimstring.cpp */; }; + 1AD394110CAB000F004BA76A /* llurldispatcher.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 1AD3940F0CAB000F004BA76A /* llurldispatcher.cpp */; }; + 1AD394130CAB001B004BA76A /* llcommandhandler.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 1AD394120CAB001B004BA76A /* llcommandhandler.cpp */; }; 1AD61F6B0AC09B1900507FB9 /* llimview.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 1AD61F6A0AC09B1900507FB9 /* llimview.cpp */; }; 1AE5D7120844FBD300278605 /* llwebbrowserctrl.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 1AE5D7100844FBD300278605 /* llwebbrowserctrl.cpp */; }; 1AEF0A580B2DFE67003F107C /* llctrlselectioninterface.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 1AEF0A560B2DFE67003F107C /* llctrlselectioninterface.cpp */; }; @@ -262,7 +266,6 @@ 5503BC2305446B20003D051F /* llmoveview.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 26F52AAB051F61DF00A80050 /* llmoveview.cpp */; }; 5503BC2505446B20003D051F /* llfloatermap.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 26F52AAD051F61DF00A80050 /* llfloatermap.cpp */; }; 5503BC2705446B20003D051F /* llregionposition.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 26F52AAF051F61DF00A80050 /* llregionposition.cpp */; }; - 5503BC2905446B20003D051F /* llasynchostbyname.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 26F52AB2051F61DF00A80050 /* llasynchostbyname.cpp */; }; 5503BC2B05446B20003D051F /* llpanelavatar.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 26F52AB4051F61DF00A80050 /* llpanelavatar.cpp */; }; 5503BC2C05446B20003D051F /* llpanelaudioprefs.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 26F52AB5051F61DF00A80050 /* llpanelaudioprefs.cpp */; }; 5503BC2D05446B20003D051F /* llfloaterbuy.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 26F52AB6051F61DF00A80050 /* llfloaterbuy.cpp */; }; @@ -430,6 +433,7 @@ 84401E320A13CCB2006720A5 /* llpanelgroupinvite.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 84401E300A13CCB2006720A5 /* llpanelgroupinvite.cpp */; }; 8833693F0C18AF33007F52DA /* llimagepng.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 8833693B0C18AF33007F52DA /* llimagepng.cpp */; }; 883369400C18AF33007F52DA /* llpngwrapper.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 8833693C0C18AF33007F52DA /* llpngwrapper.cpp */; }; + 8849626C0C7B3E8A00A777FB /* llares.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 8849626B0C7B3E8A00A777FB /* llares.cpp */; }; 88A95BB20C14D5FC0027E363 /* llsrv.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 88A95BB10C14D5FC0027E363 /* llsrv.cpp */; }; 88A95BCA0C14D92C0027E363 /* libresolv.dylib in Frameworks */ = {isa = PBXBuildFile; fileRef = 88A95BC90C14D92C0027E363 /* libresolv.dylib */; }; 88AA282C0C17720D0032DF53 /* libpng12.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 88AA282B0C17720D0032DF53 /* libpng12.a */; }; @@ -515,7 +519,6 @@ 99BB516F099AC1E9004BF9F2 /* llviewchildren.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 99BB516D099AC1E9004BF9F2 /* llviewchildren.cpp */; }; 99BB5172099AC1FC004BF9F2 /* llcurrencyuimanager.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 99BB5170099AC1FC004BF9F2 /* llcurrencyuimanager.cpp */; }; 99BB5176099AC2A4004BF9F2 /* llconfirmationmanager.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 99BB5174099AC2A4004BF9F2 /* llconfirmationmanager.cpp */; }; - 99C6BFAA0A1BBD4800419AE7 /* llfloaterhtmlfind.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 99C6BFA90A1BBD4800419AE7 /* llfloaterhtmlfind.cpp */; }; 99C7B320081F128400499A23 /* llvfsthread.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 91A154F8081DC15E0089988C /* llvfsthread.cpp */; }; 99C9FA670B6AD9BF00A1BBA6 /* SLVoice in Resources */ = {isa = PBXBuildFile; fileRef = 99C9FA660B6AD9BF00A1BBA6 /* SLVoice */; }; 99DB67DF07C161A500CF3185 /* llmediaimplquicktime.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 99DB67DB07C161A500CF3185 /* llmediaimplquicktime.cpp */; }; @@ -863,6 +866,8 @@ 1A5104580ABF60BF00520F6D /* llviewerassetstorage.h */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.c.h; path = llviewerassetstorage.h; sourceTree = ""; }; 1A57B92C09F8303A004D8B1A /* lllslconstants.h */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.c.h; path = lllslconstants.h; sourceTree = ""; }; 1A57B92D09F8303A004D8B1A /* llagentconstants.h */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.c.h; path = llagentconstants.h; sourceTree = ""; }; + 1A57CD2B0C9EFE9900B6EB24 /* llfloaterlagmeter.cpp */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; path = llfloaterlagmeter.cpp; sourceTree = ""; }; + 1A57CD2D0C9EFEA400B6EB24 /* llfloaterlagmeter.h */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.c.h; path = llfloaterlagmeter.h; sourceTree = ""; }; 1A5B3B530A70146900A90391 /* llfloaterbump.h */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.c.h; path = llfloaterbump.h; sourceTree = ""; }; 1A5B3B540A70147000A90391 /* llfloaterbump.cpp */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; path = llfloaterbump.cpp; sourceTree = ""; }; 1A61A7EF0A5ED446009FE3D2 /* llfloateravatarpicker.cpp */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; path = llfloateravatarpicker.cpp; sourceTree = ""; }; @@ -897,6 +902,12 @@ 1A9EC236083EA0100023D510 /* llfloatereditui.cpp */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; path = llfloatereditui.cpp; sourceTree = ""; }; 1A9EC23A083EA01F0023D510 /* llfloatereditui.h */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.c.h; path = llfloatereditui.h; sourceTree = ""; }; 1AB0DADC0A52E8A0001CACEB /* message_template.msg */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = text; name = message_template.msg; path = ../../scripts/messages/message_template.msg; sourceTree = SOURCE_ROOT; }; + 1AD3940C0CAB0003004BA76A /* llurlsimstring.h */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.c.h; path = llurlsimstring.h; sourceTree = ""; }; + 1AD3940D0CAB0003004BA76A /* llurldispatcher.h */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.c.h; path = llurldispatcher.h; sourceTree = ""; }; + 1AD3940E0CAB000F004BA76A /* llurlsimstring.cpp */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; path = llurlsimstring.cpp; sourceTree = ""; }; + 1AD3940F0CAB000F004BA76A /* llurldispatcher.cpp */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; path = llurldispatcher.cpp; sourceTree = ""; }; + 1AD394120CAB001B004BA76A /* llcommandhandler.cpp */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; path = llcommandhandler.cpp; sourceTree = ""; }; + 1AD394140CAB0023004BA76A /* llcommandhandler.h */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.c.h; path = llcommandhandler.h; sourceTree = ""; }; 1AD61F6A0AC09B1900507FB9 /* llimview.cpp */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; path = llimview.cpp; sourceTree = ""; }; 1AD61F6C0AC09B2600507FB9 /* llimview.h */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.c.h; path = llimview.h; sourceTree = ""; }; 1AE5D70F0844FBD200278605 /* llwebbrowserctrl.h */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.c.h; path = llwebbrowserctrl.h; sourceTree = ""; }; @@ -1110,7 +1121,6 @@ 26F52AAB051F61DF00A80050 /* llmoveview.cpp */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; path = llmoveview.cpp; sourceTree = SOURCE_ROOT; }; 26F52AAD051F61DF00A80050 /* llfloatermap.cpp */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; path = llfloatermap.cpp; sourceTree = SOURCE_ROOT; }; 26F52AAF051F61DF00A80050 /* llregionposition.cpp */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; path = llregionposition.cpp; sourceTree = SOURCE_ROOT; }; - 26F52AB2051F61DF00A80050 /* llasynchostbyname.cpp */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; path = llasynchostbyname.cpp; sourceTree = SOURCE_ROOT; }; 26F52AB4051F61DF00A80050 /* llpanelavatar.cpp */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; path = llpanelavatar.cpp; sourceTree = SOURCE_ROOT; }; 26F52AB5051F61DF00A80050 /* llpanelaudioprefs.cpp */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; path = llpanelaudioprefs.cpp; sourceTree = SOURCE_ROOT; }; 26F52AB6051F61DF00A80050 /* llfloaterbuy.cpp */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; path = llfloaterbuy.cpp; sourceTree = SOURCE_ROOT; }; @@ -1508,6 +1518,7 @@ 8833693C0C18AF33007F52DA /* llpngwrapper.cpp */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; path = llpngwrapper.cpp; sourceTree = ""; }; 8833693D0C18AF33007F52DA /* llpngwrapper.h */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.c.h; path = llpngwrapper.h; sourceTree = ""; }; 8833693E0C18AF33007F52DA /* llimagepng.h */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.c.h; path = llimagepng.h; sourceTree = ""; }; + 8849626B0C7B3E8A00A777FB /* llares.cpp */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; name = llares.cpp; path = ../llcommon/llares.cpp; sourceTree = SOURCE_ROOT; }; 88A95BB10C14D5FC0027E363 /* llsrv.cpp */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; path = llsrv.cpp; sourceTree = SOURCE_ROOT; }; 88A95BC90C14D92C0027E363 /* libresolv.dylib */ = {isa = PBXFileReference; lastKnownFileType = "compiled.mach-o.dylib"; name = libresolv.dylib; path = /usr/lib/libresolv.dylib; sourceTree = ""; }; 88AA282B0C17720D0032DF53 /* libpng12.a */ = {isa = PBXFileReference; lastKnownFileType = archive.ar; path = libpng12.a; sourceTree = BUILT_PRODUCTS_DIR; }; @@ -1892,10 +1903,8 @@ 99BB5171099AC1FC004BF9F2 /* llcurrencyuimanager.h */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.c.h; path = llcurrencyuimanager.h; sourceTree = SOURCE_ROOT; }; 99BB5174099AC2A4004BF9F2 /* llconfirmationmanager.cpp */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; path = llconfirmationmanager.cpp; sourceTree = SOURCE_ROOT; }; 99BB5175099AC2A4004BF9F2 /* llconfirmationmanager.h */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.c.h; path = llconfirmationmanager.h; sourceTree = SOURCE_ROOT; }; - 99C6BFA80A1BBD4800419AE7 /* llfloaterhtmlfind.h */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.c.h; path = llfloaterhtmlfind.h; sourceTree = ""; }; - 99C6BFA90A1BBD4800419AE7 /* llfloaterhtmlfind.cpp */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; path = llfloaterhtmlfind.cpp; sourceTree = ""; }; 99C9FA660B6AD9BF00A1BBA6 /* SLVoice */ = {isa = PBXFileReference; lastKnownFileType = "compiled.mach-o.executable"; name = SLVoice; path = "vivox-runtime/universal-darwin/SLVoice"; sourceTree = SOURCE_ROOT; }; - 99D5703305BDEFD7004DE704 /* AutoUpdater.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = AutoUpdater.app; sourceTree = BUILT_PRODUCTS_DIR; }; + 99D5703305BDEFD7004DE704 /* AutoUpdater.app */ = {isa = PBXFileReference; includeInIndex = 0; lastKnownFileType = wrapper.application; path = AutoUpdater.app; sourceTree = BUILT_PRODUCTS_DIR; }; 99D5703505BDEFD8004DE704 /* AutoUpdater-Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.xml; path = "AutoUpdater-Info.plist"; sourceTree = SOURCE_ROOT; }; 99D8B25508735BFE002F8938 /* material_codes.h */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.c.h; path = material_codes.h; sourceTree = ""; }; 99DB67DA07C161A500CF3185 /* llmediaimplquicktime.h */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.c.h; path = llmediaimplquicktime.h; sourceTree = ""; }; @@ -2385,6 +2394,10 @@ 26F529A0051F61CD00A80050 /* newview */ = { isa = PBXGroup; children = ( + 1AD394120CAB001B004BA76A /* llcommandhandler.cpp */, + 1AD3940E0CAB000F004BA76A /* llurlsimstring.cpp */, + 1AD3940F0CAB000F004BA76A /* llurldispatcher.cpp */, + 1A57CD2B0C9EFE9900B6EB24 /* llfloaterlagmeter.cpp */, 79256EA10C57D6A4000AAFA4 /* llfloatervoicewizard.cpp */, 79256EA20C57D6A4000AAFA4 /* llfloatervoicewizard.h */, AA11834E0C1DF9C400FDE5BA /* llpanelaudiovolume.cpp */, @@ -2412,7 +2425,6 @@ 26F52A5D051F61DF00A80050 /* llagentpilot.cpp */, FD59ED5D0AF2AF460086642A /* llassetuploadresponders.cpp */, FD59ED5E0AF2AF460086642A /* llassetuploadresponders.h */, - 26F52AB2051F61DF00A80050 /* llasynchostbyname.cpp */, 918166CA06516C59005727DC /* llaudiosourcevo.cpp */, 26F52A33051F61DF00A80050 /* llbbox.cpp */, 26F52ABF051F61DF00A80050 /* llbox.cpp */, @@ -2500,8 +2512,6 @@ 26F52A7E051F61DF00A80050 /* llfloatergroups.cpp */, 91A155FE081EE7F70089988C /* llfloaterhtml.cpp */, 91A15600081EE8060089988C /* llfloaterhtml.h */, - 99C6BFA90A1BBD4800419AE7 /* llfloaterhtmlfind.cpp */, - 99C6BFA80A1BBD4800419AE7 /* llfloaterhtmlfind.h */, A3077BFF09DCB8140059ED75 /* llfloaterhtmlhelp.cpp */, A3077C0009DCB8140059ED75 /* llfloaterhtmlhelp.h */, 91B9EC4C06370E4D007B3F3E /* llfloaterimagepreview.cpp */, @@ -2797,6 +2807,7 @@ 6192211E074A9B57005E1F34 /* llcommon */ = { isa = PBXGroup; children = ( + 8849626B0C7B3E8A00A777FB /* llares.cpp */, 295542580C3B371500025801 /* llversionviewer.h */, CB162DB40C6CCCFE00BF83BB /* llextendedstatus.h */, 1A9897E70B98E2F4005C45D7 /* llbase32.h */, @@ -3580,6 +3591,10 @@ 997B4BCB060157E5001B0407 /* newview headers */ = { isa = PBXGroup; children = ( + 1AD394140CAB0023004BA76A /* llcommandhandler.h */, + 1AD3940C0CAB0003004BA76A /* llurlsimstring.h */, + 1AD3940D0CAB0003004BA76A /* llurldispatcher.h */, + 1A57CD2D0C9EFEA400B6EB24 /* llfloaterlagmeter.h */, 997B4CF006015822001B0407 /* audiosettings.h */, 997B4D2406015823001B0407 /* head.h */, 997B4D2306015823001B0407 /* llagent.h */, @@ -4166,7 +4181,7 @@ ); runOnlyForDeploymentPostprocessing = 0; shellPath = /bin/sh; - shellScript = "# Glue together intel and ppc versions of .a files\nLIBS=\"apr-1 aprutil-1 expat ogg vorbis fmod freetype cares llcurl lljpeg png12 openjpeg vorbisenc vorbisfile xmlrpc\"\nLIBDIR=\"${SRCROOT}/../../libraries\"\n\ncd \"${LIBDIR}\"\n\nif [ \\! -e ppc-darwin ]\nthen\n\tln -s powerpc-darwin ppc-darwin\nfi\n\nmkdir -p \"${BUILT_PRODUCTS_DIR}\"\n\nfor i in ${LIBS}; do\n\tNEED_UPDATE=false\n\tARCH_COUNT=0\n\tOUT=\"${BUILT_PRODUCTS_DIR}/lib$i.a\"\n\tTEST_ARCH=`echo \"${ARCHS}\" | grep i386`\n\tif [ -n \"$TEST_ARCH\" ]; then\n\t\tIN_i386=\"i386-darwin/lib_release/lib$i.a\"\n\t\tARCH_COUNT=`expr $ARCH_COUNT \"+\" 1`\n\t\tif [ \"$IN_i386\" -nt \"$OUT\" ]; then\n\t\t\tNEED_UPDATE=true\n\t\tfi\n\tfi\n\tTEST_ARCH=`echo \"${ARCHS}\" | grep ppc`\n\tif [ -n \"$TEST_ARCH\" ]; then\n\t\tIN_ppc=\"ppc-darwin/lib_release/lib$i.a\"\n\t\tARCH_COUNT=`expr $ARCH_COUNT \"+\" 1`\n\t\tif [ \"$IN_ppc\" -nt \"$OUT\" ]; then\n\t\t\tNEED_UPDATE=true\n\t\tfi\n\tfi\n\tif [ $ARCH_COUNT -eq 0 ]; then\n\t\techo \"No supported architectures found.\"\n\t\texit 1\n\tfi\n\tif [ ! -f \"$OUT\" -o NEED_UPDATE = \"true\" ]; then\n\t\techo Preparing third party library lib$i.a\n\t\tif [ $ARCH_COUNT -eq 1 ]; then\n\t\t\tIN=\"$IN_i386\"\"$IN_ppc\"\n\t\t\t#echo cp \"$IN\" \"$OUT\"\n\t\t\tcp \"$IN\" \"$OUT\"\n\t\telse\n\t\t\t#echo libtool -static -o \"$OUT\" \"$IN_i386\" \"$IN_ppc\"\n\t\t\tlibtool -static -o \"$OUT\" \"$IN_i386\" \"$IN_ppc\"\n\t\tfi\n\t\tranlib \"$OUT\"\n\telse\n\t\techo Third party library lib$i.a is up to date\n\tfi\ndone\n"; + shellScript = "# Glue together intel and ppc versions of .a files\nLIBS=\"apr-1 aprutil-1 expat ogg vorbis fmod freetype cares llcurl lljpeg png12 openjpeg vorbisenc vorbisfile xmlrpc\"\nLIBDIR=\"${SRCROOT}/../../libraries\"\n\ncd \"${LIBDIR}\"\n\nif [ \\! -e ppc-darwin ]\nthen\n\tln -s powerpc-darwin ppc-darwin\nfi\n\nmkdir -p \"${BUILT_PRODUCTS_DIR}\"\n\nfor i in ${LIBS}; do\n\tNEED_UPDATE=false\n\tARCH_COUNT=0\n\tOUT=\"${BUILT_PRODUCTS_DIR}/lib$i.a\"\n\tTEST_ARCH=`echo \"${ARCHS}\" | grep i386`\n\tif [ -n \"$TEST_ARCH\" ]; then\n\t\tIN_i386=\"i386-darwin/lib_release/lib$i.a\"\n\t\tARCH_COUNT=`expr $ARCH_COUNT \"+\" 1`\n\t\tif [ \"$IN_i386\" -nt \"$OUT\" ]; then\n\t\t\tNEED_UPDATE=true\n\t\tfi\n\tfi\n\tTEST_ARCH=`echo \"${ARCHS}\" | grep ppc`\n\tif [ -n \"$TEST_ARCH\" ]; then\n\t\tIN_ppc=\"ppc-darwin/lib_release/lib$i.a\"\n\t\tARCH_COUNT=`expr $ARCH_COUNT \"+\" 1`\n\t\tif [ \"$IN_ppc\" -nt \"$OUT\" ]; then\n\t\t\tNEED_UPDATE=true\n\t\tfi\n\tfi\n\tif [ $ARCH_COUNT -eq 0 ]; then\n\t\techo \"No supported architectures found.\"\n\t\texit 1\n\tfi\n\tif [ ! -f \"$OUT\" -o \"$NEED_UPDATE\" != \"false\" ]; then\n\t\techo Preparing third party library lib$i.a\n\t\tif [ $ARCH_COUNT -eq 1 ]; then\n\t\t\tIN=\"$IN_i386\"\"$IN_ppc\"\n\t\t\t#echo cp \"$IN\" \"$OUT\"\n\t\t\tcp \"$IN\" \"$OUT\"\n\t\telse\n\t\t\t#echo libtool -static -o \"$OUT\" \"$IN_i386\" \"$IN_ppc\"\n\t\t\tlibtool -static -o \"$OUT\" \"$IN_i386\" \"$IN_ppc\"\n\t\tfi\n\t\tranlib \"$OUT\"\n\telse\n\t\techo Third party library lib$i.a is up to date\n\tfi\ndone\n"; }; /* End PBXShellScriptBuildPhase section */ @@ -4358,7 +4373,6 @@ 5503BC2305446B20003D051F /* llmoveview.cpp in Sources */, 5503BC2505446B20003D051F /* llfloatermap.cpp in Sources */, 5503BC2705446B20003D051F /* llregionposition.cpp in Sources */, - 5503BC2905446B20003D051F /* llasynchostbyname.cpp in Sources */, 5503BC2B05446B20003D051F /* llpanelavatar.cpp in Sources */, 5503BC2C05446B20003D051F /* llpanelaudioprefs.cpp in Sources */, 5503BC2D05446B20003D051F /* llfloaterbuy.cpp in Sources */, @@ -4546,7 +4560,6 @@ 1AFA40A20A2DFC9000C13F70 /* llprefschat.cpp in Sources */, 1AFA40A50A2DFC9400C13F70 /* llfloatertest.cpp in Sources */, 1AFA40B50A2DFD7200C13F70 /* llsavedsettingsglue.cpp in Sources */, - 99C6BFAA0A1BBD4800419AE7 /* llfloaterhtmlfind.cpp in Sources */, AA0E2A610A2FDAEE0066250A /* llcontrol.cpp in Sources */, AA0E2A640A2FDB340066250A /* lltoolpipette.cpp in Sources */, AAA1336B0A3F94D000419F7C /* lluistring.cpp in Sources */, @@ -4628,6 +4641,11 @@ 1A0DA5150C3AC07800361F49 /* llviewerjointmesh_sse.cpp in Sources */, 79256EA30C57D6A5000AAFA4 /* llfloatervoicewizard.cpp in Sources */, D23289B50C453A3600304FEF /* llfloaterreleasemsg.cpp in Sources */, + 8849626C0C7B3E8A00A777FB /* llares.cpp in Sources */, + 1A57CD2C0C9EFE9900B6EB24 /* llfloaterlagmeter.cpp in Sources */, + 1AD394100CAB000F004BA76A /* llurlsimstring.cpp in Sources */, + 1AD394110CAB000F004BA76A /* llurldispatcher.cpp in Sources */, + 1AD394130CAB001B004BA76A /* llcommandhandler.cpp in Sources */, ); runOnlyForDeploymentPostprocessing = 0; }; diff --git a/linden/indra/newview/macview_Prefix.h b/linden/indra/newview/macview_Prefix.h index 1aea635..c7dd351 100644 --- a/linden/indra/newview/macview_Prefix.h +++ b/linden/indra/newview/macview_Prefix.h @@ -2,6 +2,8 @@ * @file macview_Prefix.h * @brief Prefix header for all source files of the 'newview' target in the 'newview' project. * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // MBW -- This doesn't work. There are some conflicts between things in Carbon.h and some of the linden source. diff --git a/linden/indra/newview/moviemaker.cpp b/linden/indra/newview/moviemaker.cpp index 34e5a16..611b6d2 100644 --- a/linden/indra/newview/moviemaker.cpp +++ b/linden/indra/newview/moviemaker.cpp @@ -2,6 +2,8 @@ * @file moviemaker.cpp * @brief MovieMaker implementation * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ // =============================================== @@ -33,9 +36,7 @@ #include "llviewerprecompiledheaders.h" #include "moviemaker.h" -#include -#include -#include +#include #include "llmemtype.h" #if LL_WINDOWS diff --git a/linden/indra/newview/moviemaker.h b/linden/indra/newview/moviemaker.h index 056e683..198cb9b 100644 --- a/linden/indra/newview/moviemaker.h +++ b/linden/indra/newview/moviemaker.h @@ -2,6 +2,8 @@ * @file moviemaker.h * @brief MovieMaker class definition * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef _MOVIEMAKER_H diff --git a/linden/indra/newview/newview.vcproj b/linden/indra/newview/newview.vcproj index 726f77a..6fda220 100644 --- a/linden/indra/newview/newview.vcproj +++ b/linden/indra/newview/newview.vcproj @@ -37,7 +37,7 @@ Name="VCCustomBuildTool"/> - - + + - - + + + + + + + + - - + + + + + + - - + + - - @@ -752,6 +749,10 @@ > + + @@ -1874,15 +1875,11 @@ > - - + + @@ -2266,6 +2267,10 @@ > + + @@ -3428,6 +3433,10 @@ > + + diff --git a/linden/indra/newview/noise.cpp b/linden/indra/newview/noise.cpp index 930c91e..1de7d27 100644 --- a/linden/indra/newview/noise.cpp +++ b/linden/indra/newview/noise.cpp @@ -2,6 +2,8 @@ * @file noise.cpp * @brief Perlin noise routines for procedural textures, etc * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" diff --git a/linden/indra/newview/noise.h b/linden/indra/newview/noise.h index 142718a..52d6fba 100644 --- a/linden/indra/newview/noise.h +++ b/linden/indra/newview/noise.h @@ -2,6 +2,8 @@ * @file noise.h * @brief Perlin noise routines for procedural textures, etc * + * $LicenseInfo:firstyear=2000&license=viewergpl$ + * * Copyright (c) 2000-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_NOISE_H diff --git a/linden/indra/newview/pipeline.cpp b/linden/indra/newview/pipeline.cpp index 8e42504..758455d 100644 --- a/linden/indra/newview/pipeline.cpp +++ b/linden/indra/newview/pipeline.cpp @@ -2,6 +2,8 @@ * @file pipeline.cpp * @brief Rendering pipeline. * + * $LicenseInfo:firstyear=2005&license=viewergpl$ + * * Copyright (c) 2005-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #include "llviewerprecompiledheaders.h" @@ -745,13 +748,7 @@ U32 LLPipeline::addObject(LLViewerObject *vobj) void LLPipeline::resetFrameStats() { - mCompilesStat.addValue(sCompiles); - mLightingChangesStat.addValue(mLightingChanges); - mGeometryChangesStat.addValue(mGeometryChanges); mTrianglesDrawnStat.addValue(mTrianglesDrawn/1000.f); - mVerticesRelitStat.addValue(mVerticesRelit); - mNumVisibleFacesStat.addValue(mNumVisibleFaces); - mNumVisibleDrawablesStat.addValue((S32)mVisibleList.size()); mTrianglesDrawn = 0; sCompiles = 0; @@ -853,8 +850,6 @@ void LLPipeline::updateMove() return; } - mMoveChangesStat.addValue((F32)mMovedList.size()); - for (LLDrawable::drawable_set_t::iterator iter = mRetexturedList.begin(); iter != mRetexturedList.end(); ++iter) { @@ -1810,15 +1805,18 @@ void LLPipeline::postSort(LLCamera& camera) // Draw face highlights for selected faces. if (gSelectMgr->getTEMode()) { - LLViewerObject *vobjp; - S32 te; - gSelectMgr->getSelection()->getFirstTE(&vobjp,&te); - - while (vobjp) + struct f : public LLSelectedTEFunctor { - mSelectedFaces.push_back(vobjp->mDrawable->getFace(te)); - gSelectMgr->getSelection()->getNextTE(&vobjp,&te); - } + virtual bool apply(LLViewerObject* object, S32 te) + { + if (object->mDrawable) + { + gPipeline.mSelectedFaces.push_back(object->mDrawable->getFace(te)); + } + return true; + } + } func; + gSelectMgr->getSelection()->applyToTEs(&func); } } diff --git a/linden/indra/newview/pipeline.h b/linden/indra/newview/pipeline.h index 06bfb73..8b64b63 100644 --- a/linden/indra/newview/pipeline.h +++ b/linden/indra/newview/pipeline.h @@ -2,6 +2,8 @@ * @file pipeline.h * @brief Rendering pipeline definitions * + * $LicenseInfo:firstyear=2001&license=viewergpl$ + * * Copyright (c) 2001-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,6 +26,7 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ #ifndef LL_PIPELINE_H @@ -346,19 +349,12 @@ public: BOOL mBackfaceCull; S32 mTrianglesDrawn; LLStat mTrianglesDrawnStat; - LLStat mCompilesStat; S32 mVerticesRelit; - LLStat mVerticesRelitStat; S32 mLightingChanges; - LLStat mLightingChangesStat; S32 mGeometryChanges; - LLStat mGeometryChangesStat; - LLStat mMoveChangesStat; S32 mNumVisibleFaces; - LLStat mNumVisibleFacesStat; - LLStat mNumVisibleDrawablesStat; static S32 sCompiles; diff --git a/linden/indra/newview/postbuild.bat b/linden/indra/newview/postbuild.bat index d71a81e..0eabb87 100644 --- a/linden/indra/newview/postbuild.bat +++ b/linden/indra/newview/postbuild.bat @@ -23,6 +23,7 @@ copy ..\..\libraries\i686-win32\lib_debug\softokn3.dll .\debug\ /y copy ..\..\libraries\i686-win32\lib_debug\ssl3.dll .\debug\ /y copy ..\..\libraries\i686-win32\lib_debug\xpcom.dll .\debug\ /y copy ..\..\libraries\i686-win32\lib_debug\xul.dll .\debug\ /y +copy ..\..\libraries\i686-win32\lib_debug\openjpeg.dll .\debug\ /y rem --- this is required for mozilla debug builds and displays the aborty/retry/ignore dialog on an assert - crashes without it --- copy ..\..\libraries\i686-win32\lib_debug\windbgdlg.exe .\debug\ /y @@ -65,6 +66,7 @@ copy ..\..\libraries\i686-win32\lib_release\softokn3.dll .\Release\ /y copy ..\..\libraries\i686-win32\lib_release\ssl3.dll .\Release\ /y copy ..\..\libraries\i686-win32\lib_release\xpcom.dll .\Release\ /y copy ..\..\libraries\i686-win32\lib_release\xul.dll .\Release\ /y +copy ..\..\libraries\i686-win32\lib_release\openjpeg.dll .\Release\ /y rem --- runtime pieces for the bHear stuff. copy .\vivox-runtime\i686-win32\tntk.dll .\ /y @@ -100,6 +102,7 @@ copy ..\..\libraries\i686-win32\lib_release\softokn3.dll .\ReleaseNoOpt\ /y copy ..\..\libraries\i686-win32\lib_release\ssl3.dll .\ReleaseNoOpt\ /y copy ..\..\libraries\i686-win32\lib_release\xpcom.dll .\ReleaseNoOpt\ /y copy ..\..\libraries\i686-win32\lib_release\xul.dll .\ReleaseNoOpt\ /y +copy ..\..\libraries\i686-win32\lib_release\openjpeg.dll .\ReleaseNoOpt\ /y rem --- runtime pieces for the bHear stuff. copy .\vivox-runtime\i686-win32\tntk.dll . /y @@ -135,6 +138,7 @@ copy ..\..\libraries\i686-win32\lib_release\softokn3.dll .\ReleaseForDownload\ copy ..\..\libraries\i686-win32\lib_release\ssl3.dll .\ReleaseForDownload\ /y copy ..\..\libraries\i686-win32\lib_release\xpcom.dll .\ReleaseForDownload\ /y copy ..\..\libraries\i686-win32\lib_release\xul.dll .\ReleaseForDownload\ /y +copy ..\..\libraries\i686-win32\lib_release\openjpeg.dll .\ReleaseForDownload\ /y rem --- runtime pieces for the bHear stuff. copy .\vivox-runtime\i686-win32\tntk.dll .\ /y copy .\vivox-runtime\i686-win32\libeay32.dll .\ /y diff --git a/linden/indra/newview/randgauss.h b/linden/indra/newview/randgauss.h index d27ece1..5568459 100644 --- a/linden/indra/newview/randgauss.h +++ b/linden/indra/newview/randgauss.h @@ -2,6 +2,8 @@ * @file randgauss.h * @brief randgauss class definition * + * $LicenseInfo:firstyear=2003&license=viewergpl$ + * * Copyright (c) 2003-2007, Linden Research, Inc. * * Second Life Viewer Source Code @@ -24,10 +26,9 @@ * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ */ -#include // for rand() - const F32 table[][2] = { {.00f, .5f}, {.01f, .504f}, diff --git a/linden/indra/newview/releasenotes.txt b/linden/indra/newview/releasenotes.txt index 616dcaa..424f44b 100644 --- a/linden/indra/newview/releasenotes.txt +++ b/linden/indra/newview/releasenotes.txt @@ -1,36 +1,71 @@ -Release Notes for Second Life 1.18.3(5) September 20, 2007 +Release Notes for Second Life 1.18.4(0) October 17, 2007 ===================================== -Bug fixes: -* Fixed login failure when declining optional updates -* Fixed VWR-2487: Covenant Details between live version and release candidate version -* Fixed VWR-2484: Icons missing from Mac OS X build -* Fixed VWR-2482: build tree misses the cursors_mac directory -* Fixed VWR-2378: Failure to enable the "Update" button in the profile/classifieds tab, after a "Set Location" update. - -Release Notes for Second Life 1.18.3(4) September 14, 2007 -===================================== -Bug fixes: -* Fixed VWR-2378: Failure to enable the "Update" button in the profile/classifieds tab, after a "Set Location" update. +New features: +* Help > Lag Meter; monitors Client, Network and Server lag and reports possible causes -Release Notes for Second Life 1.18.3(3) September 12, 2007 -===================================== Changes: -* Reverted map beacon behavior (per VWR-2270) - -LSL changes: -* VWR-2265: Mis-spelled LSL constant OBJECT_UNKOWN_DETAIL renamed to OBJECT_UNKNOWN_DETAIL -** Scripts written with the old, mis-spelled constant will not recompile unless corrected +* Visual changes in preparation for a forthcoming release of new in-world search +** Opt-in and opt-out checkboxes for Resident Profile, Parcels, For Sale Objects, Not For Sale Objects, Regions, and Groups +* About Land description field is now a three-line text box +* Minimap indicators for "above" and "below" updated +** After the next server update, friends will appear in a different color Bug fixes: -* Enrollment fees are no longer displayed with decimals -* VWR-2275: Linux 1.18.3 Won't Link -* VWR-2283: Some changes to groups cannot be saved -* VWR-2324: llkdu.dll needs updating in RC viewer +* Fixed invisible sculpted prims when sculpted texture contains alpha +* Fixed scope of drag-select with locked objects +* Fixed link order of drag-selected objects +* Fixed Accept Notices flag in Group Panel General tab not saving value +* Fixed Linux viewer preferences for choosing the cache location or chat log location +* Fixed Apply button disabled after setting group preferences +* Fixed Apply button failing to grey out after selecting 'List Group in Profile' +* Fixed filename filter for Linux/GTK file picker +* Fixed Linux/GTK file picker not remembering most recent directory +* Fixed channel argument in Linux client +* Fixed muted particles not clearing +* Fixed Show in Search option not carrying over to copied object +* Fixed muted users disappearing from Active Speakers +* Fixed Mature content flag when searching All +* Fixed viewer crash when pasting/typing UTF8 text in the object For Sale price box +* Fixed Gesture Editor sounds not initialized +* Fixed Group enrollment fee accepting floating point +* Fixed 'Quiet Snapshots to Disk' and 'Disable Camera Constraints' not persisting across sessions +* Fixed dot characters in various fields +* Disabled Add to Outfit and Replace Outfit options on the top-level Clothing folder +* MISC-567: Multiple system folders (e.g., '100 Lost and Found Folders') in inventory +* VWR-2471: SL-viewer chrashes after opening the 10th group-info-window +* VWR-2444: Menu background colors aren't settable in colors_base.xml * VWR-2291: LOD defaults are now too aggressive in RC 1.18.3 -* VWR-2307: secondlife startup shell script needs a comment about gdb now - +* VWR-2283: Some changes to groups cannot be saved +* VWR-2116: Viewer crashes when starting a new Group IM session under Japanese UI +* VWR-2104: long avatar names overflow on the chat history window volume control/muting section +* VWR-2065: Custom Snapshot setting do not save for next Snapshot +* VWR-2041: Allow using voice component on another computer +* VWR-1945: toolbox floater displays window elements incorrectly when minimized then moved. +* VWR-1944: Active gestures sometimes fail to show in the Active Gestures list +* VWR-1888: Characters missing in IM window +* VWR-1724: HUD zoom snaps back after selecting another HUD object +* VWR-1695: llGiveInventoryList objects spam the owner with messages when the recipient is in Busy mode +* VWR-1590: Keyboard changes inventory selection after right-click +* VWR-1562: llassert(mNumDescendantsSelected >= 0) with crash and loop. (Debug build) +* VWR-1448: llSetText on non-root prims is unreliable (including after relogs) +* VWR-1408: Online status viewable via Groups even if 'Make my online status visible only to my Friends' is set +* VWR-1399: Client crashes when viewing details of an empty proposal window +* VWR-1096: llPlaySound does not play whilst in HUD depending on HUD attachment point +* VWR-1045: Client crashes with no warning when uploading corrupted TGA file +* VWR-851: Viewer Crashes in high texture environments when moving or when panning with camera. +* VWR-813: Recent Items tab shows folders with no matching items +* VWR-738: SL crashes when loading with a GTK_IM scim module +* VWR-379: Fix shell scripts to use bash and not sh when appropriate. +* VWR-333: 'Unable to load gesture.' or 'Gesture is missing from database.' on login +* VWR-315: Script changes in the editor may be cancelled because of lag +* VWR-851: Viewer Crashes in high texture environments when moving or when panning with camera. +* VWR-813: Recent Items tab shows folders with no matching items +* VWR-738: SL crashes when loading with a GTK_IM scim module +* VWR-379: Fix shell scripts to use bash and not sh when appropriate. +* VWR-333: 'Unable to load gesture.' or 'Gesture is missing from database.' on login +* VWR-315: Script changes in the editor may be cancelled because of lag -Release Notes for Second Life 1.18.3(2) August 27, 2007 +Release Notes for Second Life 1.18.3(5) September 28, 2007 ===================================== Changes: * Changed Bug Reporting links to http:// instead of https:// @@ -38,13 +73,24 @@ Changes: * Removed 'Ping User' in statistics window (was returning 0, as userserver no longer exists) * Removed 'Open' menu option when clothing is selected (as 'Wear' is available) * Added minimize button to Inventory +* Updated voice components to improve quality and address VWR-1532 +* Added name of viewer release channel to embedded browser agent ID string +* Reverted map beacon behavior (per VWR-2270) + +Known issues: +* Sculpted prims with alpha in the sculpted texture are invisible +* The command line option '-drop' does not work on Linux or OSX clients. +* VWR-2268: Role Description causes Apply Changes, Ignore Changes, Cancel alert even if you don't have rights to change +* VWR-2551: Error in macview.xcodeproj -- invalid dependencies +* VWR-2404: lossless texture compression on small textures not lossless +* VWR-2552: Telehub gui very broken in RC LSL changes: * Ability to get details about an object by object key: ** list llGetObjectDetails(key id, list params) *** id = the key of the object to get info about. *** params = a list of the object details requested: [OBJECT_NAME, OBJECT_OWNER] -*** returns a list of values in the order requested: [ "Object_Name", ] +*** returns a list of values in the order requested: [ 'Object_Name', ] **** OBJECT_UNKNOWN_DETAIL Returned by llGetObjectDetails when passed an invalid object parameter type. **** OBJECT_NAME Used with llGetObjectDetails to get an object's name. **** OBJECT_DESC Used with llGetObjectDetails to get an object's description. @@ -56,6 +102,9 @@ LSL changes: **** OBJECT_CREATOR Used with llGetObjectDetails to get an object's creator's key. Bug fixes: +* Fixed default eyes appearing gray +* Fixed viewer source linking error +* Enrollment fees are no longer displayed with decimals * Fixed inworld map region search failing if a space is included after the region name * Fixed Appearance editor preview squares after changing tabs * Fixed a bug with LODs for sculpted prims @@ -72,55 +121,62 @@ Bug fixes: * Fixed client on 64-bit Linux systems that cannot find their GL drivers * Improved Linux client threading * Improved client performance after closing an inventory folder with a large number of items -* CID-633: Possible string overflow (and generally lame code) -* CID-634: Possible string overflow (and generally lame code) -* CID-639: Possible use of uninitialized mouse co-ordinates -* CID-641: LLToolGrab::onMouseCaptureLost() doesn't check that projectPosAgentToScreen succeeded -* CID-698: LLFloaterTexturePicker::isDirty() is not correctly overriding ancestor -* SVC-300: Spam upon TP out of Help Island Public, per calling card and landmark -* VWR-1079: Group Notice dialog: message text can't be copied and pasted -* VWR-1187: Profile > Classifieds tab shows confirmation dialog when no changes are made -* VWR-1225: Embedded notecards not functioning -* VWR-1230: Text highlighting in Chat History window is cancelled when history scrolls -* VWR-1372: Sculpt prim topology reverts to sphere unexpectedly -* VWR-1398: Appearance editor's previews do not render correctly (1.17.2) -* VWR-1460: Can not see permissions of objects in Buy Contents window when item has long name -* VWR-1564: Viewer crashes when started with the "-local" argument. -* VWR-1566: An attempt to fix the glDrawRangeElements crashes (refcount LLDrawInfo ) -* VWR-1567: Change the default item name for "snapshot to inventory" to something more usefull than "snapshot" -* VWR-1638: confused viewer - displays login and regular menus and buttons -* VWR-1640: login retires cause LLFrameStatView::setup() to seg fault -* VWR-1647: "Show end of last IM conversation" in Preferences/Communication automatically remains checked after OK-ing unchecked -* VWR-1699: Sculpt map preview inaccurate -* VWR-1714: Folders flashing in Inventory window with Filters and 'Always show folders' checked -* VWR-1721: GUI quirk in groups -* VWR-1722: Profiles are editable in two places (including Search browser) -* VWR-1736: Add a Invite to Group option to the Avatar Pie Menu -* VWR-1743: LLFloaterGroups source code inconsistencies -* VWR-1761: Group Invite Suggestion--add 'view group info' to invite dialog box -* VWR-1808: Possible crash in llviewerobjectlist -* VWR-1823: Bad typecast for 64 bit systems, llagent llfloatercustomize -* VWR-1861: Renaming items in inventory folders does not update item sort order -* VWR-1872: An attempt to fix the "empty inventory trash" crashes -* VWR-1880: Modify "Ctrl-F" to call Search/Replace Dialog when invoked inside Script Window -* VWR-1891: Detect a Debian bulid-host, as is done for Fedora -* VWR-1892: Use pkgconfig for more libraries in the standalone build -* VWR-1942: An error in the do-while example of the LSL Scripting Guide could cause infinite looping. -* VWR-1951: Hide Particles is not working from the View > Beacons menu item -* VWR-1968: Possible crash in llmultigesture.cpp -* VWR-1976: Solaris' fprintf segfaults on NULL arguments -* VWR-1987: Segfault on startup if audio doesn't initialize. -* VWR-2036: Build tools floater does not remember its position on restart -* VWR-2144: Client crashes when deleting unsaved gestures +* VWR-2487: Covenant Details between live version and release candidate version +* VWR-2275: Linux 1.18.3 Won't Link * VWR-2152: Possible crash in llviewerobjectlist -* VWR-240: Cannot input Japanese characters from keyboard on Linux -* VWR-423: Selecting group charter text causes Apply/Ignore/Cancel popup even if the text wasn't changed -* VWR-493: Objects with "Linden" in their name can't be muted -* VWR-493: Statistics bar, Packet Loss: % sign is doubled -* VWR-749: Bandwidth indicator: Kbps, should not have capital k -* VWR-819: Open the "More>>" section of the edit tools by default and persist it across sessions -* VWR-866: Sculpties suffer HORRIBLY from JPEG artifacts +* VWR-2144: Client crashes when deleting unsaved gestures +* VWR-2036: Build tools floater does not remember its position on restart +* VWR-1987: Segfault on startup if audio doesn't initialize. +* VWR-1976: Solaris' fprintf segfaults on NULL arguments +* VWR-1968: Possible crash in llmultigesture.cpp +* VWR-1951: Hide Particles is not working from the View > Beacons menu item +* VWR-1942: An error in the do-while example of the LSL Scripting Guide could cause infinite looping. +* VWR-1892: Use pkgconfig for more libraries in the standalone build +* VWR-1891: Detect a Debian bulid-host, as is done for Fedora +* VWR-1880: Modify 'Ctrl-F' to call Search/Replace Dialog when invoked inside Script Window +* VWR-1872: An attempt to fix the 'empty inventory trash' crashes +* VWR-1861: Renaming items in inventory folders does not update item sort order +* VWR-1823: Bad typecast for 64 bit systems, llagent llfloatercustomize +* VWR-1808: Possible crash in llviewerobjectlist +* VWR-1761: Group Invite Suggestion--add 'view group info' to invite dialog box +* VWR-1743: LLFloaterGroups source code inconsistencies +* VWR-1736: Add a Invite to Group option to the Avatar Pie Menu +* VWR-1722: Profiles are editable in two places (including Search browser) +* VWR-1721: GUI quirk in groups +* VWR-1714: Folders flashing in Inventory window with Filters and 'Always show folders' checked +* VWR-1699: Sculpt map preview inaccurate +* VWR-1647: 'Show end of last IM conversation' in Preferences/Communication automatically remains checked after OK-ing unchecked +* VWR-1640: login retires cause LLFrameStatView::setup() to seg fault +* VWR-1638: confused viewer - displays login and regular menus and buttons +* VWR-1567: Change the default item name for 'snapshot to inventory' to something more usefull than 'snapshot' +* VWR-1566: An attempt to fix the glDrawRangeElements crashes (refcount LLDrawInfo ) +* VWR-1564: Viewer crashes when started with the '-local' argument. +* VWR-1460: Can not see permissions of objects in Buy Contents window when item has long name +* VWR-1398: Appearance editor's previews do not render correctly (1.17.2) +* VWR-1372: Sculpt prim topology reverts to sphere unexpectedly +* VWR-1230: Text highlighting in Chat History window is cancelled when history scrolls +* VWR-1225: Embedded notecards not functioning +* VWR-1187: Profile > Classifieds tab shows confirmation dialog when no changes are made +* VWR-1079: Group Notice dialog: message text can't be copied and pasted * VWR-942: logRanOffEndOfPacket is too terse when it logs packet data, add some more info +* VWR-866: Sculpties suffer HORRIBLY from JPEG artifacts +* VWR-819: Open the 'More>>' section of the edit tools by default and persist it across sessions +* VWR-749: Bandwidth indicator: Kbps, should not have capital k +* VWR-493: Statistics bar, Packet Loss: % sign is doubled +* VWR-493: Objects with 'Linden' in their name can't be muted +* VWR-423: Selecting group charter text causes Apply/Ignore/Cancel popup even if the text wasn't changed +* VWR-240: Cannot input Japanese characters from keyboard on Linux +* SVC-300: Spam upon TP out of Help Island Public, per calling card and landmark + + +Release Notes for Second Life 1.18.2(1) September 19, 2007 +===================================== + +Changes: +* Fix URL handler exploit described here: http://blog.secondlife.com/2007/09/18/second-life-url-handler-exploit/ +* Update voice components to improve quality and address VWR-1532 +* Add name of viewer release channel to embedded browser agent ID string + Release Notes for Second Life 1.18.2(0) August 10, 2007 ===================================== @@ -128,7 +184,7 @@ Release Notes for Second Life 1.18.2(0) August 10, 2007 Bug fixes: * VWR-1936: Line editor history missing from First Look: Voice * Adjusted thread priorities and buffering algorithms in SLVoice to improve performance on low-end machines -* Added a DC bias removal filter to SLVoice, which should remove "popping" artifacts heard with some microphones +* Added a DC bias removal filter to SLVoice, which should remove 'popping' artifacts heard with some microphones * Fixed: Audio devices added to a system after launch of client do not appear in the device menu * Fixed: The first time opening the prefs window after launch kicks the user out of their voice channel @@ -139,7 +195,7 @@ New Features: * In-World Voice Chat ** In-world Voice Chat is now part of the main viewer. ** You can see and manage all voice settings in Edit > Preferences > Voice Chat. -** Voice is off by default. To enable (and disable) voice, visit Edit > Preferences > Voice Chat and check/uncheck the box beside "Enable voice chat". +** Voice is off by default. To enable (and disable) voice, visit Edit > Preferences > Voice Chat and check/uncheck the box beside 'Enable voice chat'. ** A voice set-up wizard appears during first voice use to help residents set up voice and adjust their mic volume and tuning. You should run the voice set-up wizard even if you only want the ability to hear others and do not wish to speak. ** Push-to-Talk is part of the Voice feature. Push-to-Talk is ON by default, which means Resident mics are OFF by default. ** Speech gestures for voice are included in the Library, in Gestures > Speech Gestures. These gestures need to be activated in order to work; they are off by default. @@ -150,7 +206,7 @@ Changes: * Text from objects can be muted. Bug fixes: -* VWR-1797: Remove mention of "Live Help" from Crash Logger +* VWR-1797: Remove mention of 'Live Help' from Crash Logger * VWR-1732: Pressing Enter, with multiple inventory objects selected, crashes viewer * VWR-1729: indra/lscript/lscript_compile/indra.l: avoid yyunput hack on Windows build * VWR-1723: Possible crash in llvopartgroup @@ -164,14 +220,14 @@ Bug fixes: * VWR-1613: Overuse of virtual * VWR-1612: LLRenderPass::Pushbatch and LLViewerImage::addTextureStats tuning * VWR-1586: Mismatched delete in llviewerparcelmgr.cpp -* VWR-1578: Two quirks in IM regarding "xxxx is typing" -* VWR-1471: Inspect (Pie menu > More > More > Inspect) shows nothing on first use when "only select own objects" is enabled +* VWR-1578: Two quirks in IM regarding 'xxxx is typing' +* VWR-1471: Inspect (Pie menu > More > More > Inspect) shows nothing on first use when 'only select own objects' is enabled * VWR-1470: Buttons (IM, Teleport, Profile, ...) in friends list are disabled when opening friends list window * VWR-1468: LoginPacketNeverReceived dialog text is incorrect * VWR-1462: Order of right-click menu on Inventory is confusing * VWR-1453: A few old-school changes for llviewerregion.cpp * VWR-1434: Null pointer crash when terraforming -* VWR-1406: Unchecking "Go Away/AFK when idle" has no effect in 1.17.2.0 +* VWR-1406: Unchecking 'Go Away/AFK when idle' has no effect in 1.17.2.0 * VWR-1382: Some scripted objects are highlighted in red while pressing Alt with tools open * VWR-1381: libpng12.a for MacOS X is missing in 1.17.1.0 and build fails. * VWR-1358: Physical objects remain red if tools window is closed while holding Alt key @@ -194,16 +250,16 @@ Bug fixes: * VWR-238: Permissions of Roles and Rights in the german version are mased up. * VWR-102: md5 slow * SVC-371: Fix the legibility and grammar/consistency of the new llOwnerSay implementation -* SVC-193: llParticleSystem - halo of rogue particles around original particle system after 1.15 update* SVC-373: Deleting a script's code results in a non-existent file and "missing from database" error +* SVC-193: llParticleSystem - halo of rogue particles around original particle system after 1.15 update* SVC-373: Deleting a script's code results in a non-existent file and 'missing from database' error * Fixed preference for showing or hiding server combo box was not preserved -* Fixed residents with negative L$ balance can't purchase items set for sale "Original" or "Copy" that are being sold for L$0 -* "Copy SLURL to clipboard" is now enabled for an avatar's current coordinates +* Fixed residents with negative L$ balance can't purchase items set for sale 'Original' or 'Copy' that are being sold for L$0 +* 'Copy SLURL to clipboard' is now enabled for an avatar's current coordinates * Macintosh viewer now correctly opens the map and selects the destination on a SLURL request * Leading and trailing spaces are now automatically trimmed from parcel media URLs -* Corrected the spacing of the yellow "next dialog" chevron (was partially blocked by the Mute button) +* Corrected the spacing of the yellow 'next dialog' chevron (was partially blocked by the Mute button) * Corrected the error message shown when adding 11th Estate Manager * Added CPU detection for Intel Core Duo/Solo and Intel Core 2 Duo -* "Set Window Size..." setting is now correctly resumed after being minimized +* 'Set Window Size...' setting is now correctly resumed after being minimized * Added link to Qa wiki in the viewer bug reporter menu. * Updated text in Second Life Crash Logger with new support portal information * Corrected an issue with UI font scaling in the bug reporter window @@ -219,7 +275,7 @@ Changes: * Updated translations for German language viewer * Updated translations for Japanese language viewer * Updated translations for Korean language viewer -* Viewer "channel" (Release, First Look, etc) now visible at login in the lower right corner next to the version number +* Viewer 'channel' (Release, First Look, etc) now visible at login in the lower right corner next to the version number Bug fixes: * Fixed SVC-286: deleted fully-permissive objects owned by others skip trash @@ -258,12 +314,12 @@ Bug fixes: Release Notes for Second Life 1.17.1(0) June 25, 2007 ===================================== Changes: -* VWR-650: Make "Give money" permissions look different than the other permissions +* VWR-650: Make 'Give money' permissions look different than the other permissions * VWR-427: Added new menu item: Tools > Edit Linked Parts * VWR-79: PNG image support submission * Sculpties now include a one-time explanation the first time a sculptie is created. * Client and Server menus now have a one-time dialog box to explain what they are. -* "Skip 'Show next time' Dialogs..." button added to Preferences > Popups tab to skip all one time dialog boxes. +* 'Skip 'Show next time' Dialogs...' button added to Preferences > Popups tab to skip all one time dialog boxes. * Added Japanese and German language installers (Windows only) * The version of Mozilla used in the client is updated to 1.8.0.12 * F1 help now opens an external browser to the Second Life support web site. @@ -290,14 +346,14 @@ Bug fixes: * Fixed VWR-1170: LLMuteList::loadFromFile() improperly parses the mute list returned from the service * Fixed VWR-1140: About Land floater is not resizable, ban and access lists too small * Fixed VWR-1049: Trivial sizeof() miscalculatuion results in incomplete copying of CPU Brand ID string in CProcessor::AnalyzeAMDProcessor() -* Fixed VWR-1044: Unchecking "Go Away/AFK When Idle" doesn't work when manually setting Away status +* Fixed VWR-1044: Unchecking 'Go Away/AFK When Idle' doesn't work when manually setting Away status * Fixed VWR-944: Boost inclusion is inconsistent * Fixed VWR-941: Reading length data for a four-byte Variable template message misstores the length * Fixed VWR-938: ELFIO is technically optional, make this easy to capitalise on * Fixed VWR-876: sculpt texture map does not load or low priority when the texture itself is not visible in viewer frame or not cached -* Fixed VWR-873: Dead members "eVertexDataMask;" in various objects +* Fixed VWR-873: Dead members 'eVertexDataMask;' in various objects * Fixed VWR-856: llvfs.cpp: possible loss of memory blocks in LLVFS:audit() -* Fixed VWR-822: "Create new..." clothing buttons don't auto-wear items +* Fixed VWR-822: 'Create new...' clothing buttons don't auto-wear items * Fixed VWR-746: Incorrect menu item referred to when member of maximum number of groups and a group invite is received * Fixed VWR-660: When turning off Flexible Object rendering, flexible objects become permanently invisible * Fixed VWR-652: A harmless compiler warning in indra.l.cpp @@ -319,8 +375,8 @@ Bug fixes: * Fixed VWR-143: Compiler errors in llwebbrowserctrl.h * Fixed VWR-132: seg fault in lldrawpool.cpp * Fixed VWR-119: Zero missing in Sub-unit snap grid. for small fraction like 1/16 and 1/32 -* Fixed VWR-101: Get rid of "Return All" -* Fixed Inventory's "Recent Items" tab settings not persisting across logins +* Fixed VWR-101: Get rid of 'Return All' +* Fixed Inventory's 'Recent Items' tab settings not persisting across logins * Fixed line breaks showing up as * in various windows. Release Notes for Second Life 1.17.0(12) June 13, 2007 @@ -331,7 +387,7 @@ Changes: ** Viewing an embedded notecard or landmark no longer adds it to your inventory. ** Muting the sender of notecards, inventory, textures, etc., now removes all blue pop-ups in the upper right corner from that sender. ** Offline inventory transfers and group invites now include the name of the item or group, along with group role, in the email. -* Added "Clear Browser Cache" button to web prefs. +* Added 'Clear Browser Cache' button to web prefs. ** This only affects the embedded browser, not any other browsers installed on your system * Embedded Mozilla browser now supports cookies. * Preliminary support added to the Windows installer for selecting a language (English, Korean) @@ -340,16 +396,16 @@ Changes: Bug fixes: * Fixed a client crash while in startup * Fixed group chat reopening with one message and an error after closing group chat -* Fixed "Stop All Animations" when stuck in an animation after teleporting +* Fixed 'Stop All Animations' when stuck in an animation after teleporting * Fixed group messages to allow the use of UTF8 characters -* Fixed "Show Owners" from automatically turning on again -* Fixed an issue with "Release Controls" when an object is taken and rerezed. +* Fixed 'Show Owners' from automatically turning on again +* Fixed an issue with 'Release Controls' when an object is taken and rerezed. * Fixed an issue with texture picker not displaying any results unless inventory had been shown * Fixed chat history to not show muted resident chat -* Fixed "Mute Resident" button, now opens the user picker +* Fixed 'Mute Resident' button, now opens the user picker * Fixed group ability settings for group owners in German language viewer * Fixed embedded Mozilla browser to work with HTTPS sites (affected Windows only) -* Notecards no longer display the "Keep" and "Discard" buttons when opened from inventory +* Notecards no longer display the 'Keep' and 'Discard' buttons when opened from inventory * Acquired date is now set for items dragged from the contents of a container prim * VWR-1040: crash when opening several gestures quickly * VWR-966: Minor memory leak in llfloaterpreferences.cpp and a tiny leak in llstatup.cpp @@ -359,7 +415,7 @@ Bug fixes: * VWR-869: Possible hard-loop (endless, viewer-hang) in script editor * VWR-827: Toruses are borked after making/editing sculpted prims * VWR-823: Two unintialized variables in lltexturefetch.cpp -* VWR-822: "Create new..." clothing buttons don't auto-wear items +* VWR-822: 'Create new...' clothing buttons don't auto-wear items * VWR-810: Destructor forgets to delete mFloaterContros member in llui/llview.cpp * VWR-809: Destructor fails to clean up global menus in llviewermenu.cpp * VWR-808: Incorrect cleanup in message.cpp @@ -380,7 +436,7 @@ New Features: * Sculpted Prims ** Sculpted Prims are a new primitive type that uses a texture to control its 3D shape ** See http://wiki.secondlife.com/wiki/Sculpted_Prims for FAQ and detailed information -* Add "Mute" button to block unwanted notecards, landmarks, and textures +* Add 'Mute' button to block unwanted notecards, landmarks, and textures Changes: * Improved muting of particle systems @@ -436,7 +492,7 @@ Changes: * Ctrl-Shift-W closes all windows * Inventory system folders may be sorted to top * Busy mode declines notecards and textures and silently sends all other transfers to Inventory -* L$ balance displays "Loading..." (instead of a blank) when first checking your balance +* L$ balance displays 'Loading...' (instead of a blank) when first checking your balance * Minimap is enabled when Second Life runs for the first time * Texture transfers are limited to 5 items per 10 seconds diff --git a/linden/indra/newview/res/newViewRes.rc b/linden/indra/newview/res/newViewRes.rc index 670e4e8..9094a9c 100644 --- a/linden/indra/newview/res/newViewRes.rc +++ b/linden/indra/newview/res/newViewRes.rc @@ -227,8 +227,8 @@ TOOLPIPETTE CURSOR "toolpipette.cur" // VS_VERSION_INFO VERSIONINFO - FILEVERSION 1,18,3,5 - PRODUCTVERSION 1,18,3,5 + FILEVERSION 1,18,4,0 + PRODUCTVERSION 1,18,4,0 FILEFLAGSMASK 0x3fL #ifdef _DEBUG FILEFLAGS 0x1L @@ -245,12 +245,12 @@ BEGIN BEGIN VALUE "CompanyName", "Linden Lab" VALUE "FileDescription", "Second Life" - VALUE "FileVersion", "1.18.3.5" + VALUE "FileVersion", "1.18.4.0" VALUE "InternalName", "Second Life" VALUE "LegalCopyright", "Copyright © 2001-2007, Linden Research, Inc." VALUE "OriginalFilename", "SecondLife.exe" VALUE "ProductName", "Second Life" - VALUE "ProductVersion", "1.18.3.5" + VALUE "ProductVersion", "1.18.4.0" END END BLOCK "VarFileInfo" diff --git a/linden/indra/newview/secondlife-i686.supp b/linden/indra/newview/secondlife-i686.supp index b1b30a4..43d4483 100644 --- a/linden/indra/newview/secondlife-i686.supp +++ b/linden/indra/newview/secondlife-i686.supp @@ -1,8 +1,31 @@ # @file secondlife-i686.supp # @brief Valgrind suppressions for Linux i686 viewer. # -# Copyright (c) 2000-$CurrentYear$, Linden Research, Inc. -# $License$ +# $LicenseInfo:firstyear=2000&license=viewergpl$ +# +# Copyright (c) 2000-2007, Linden Research, Inc. +# +# Second Life Viewer Source Code +# The source code in this file ("Source Code") is provided by Linden Lab +# to you under the terms of the GNU General Public License, version 2.0 +# ("GPL"), unless you have obtained a separate licensing agreement +# ("Other License"), formally executed by you and Linden Lab. Terms of +# the GPL can be found in doc/GPL-license.txt in this distribution, or +# online at http://secondlife.com/developers/opensource/gplv2 +# +# There are special exceptions to the terms and conditions of the GPL as +# it is applied to this Source Code. View the full text of the exception +# in the file doc/FLOSS-exception.txt in this software distribution, or +# online at http://secondlife.com/developers/opensource/flossexception +# +# By copying, modifying or distributing this software, you acknowledge +# that you have read and understood your obligations described above, +# and agree to abide by those obligations. +# +# ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO +# WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, +# COMPLETENESS OR PERFORMANCE. +# $/LicenseInfo$ # # This is a Valgrind suppression file for use on the viewer. # diff --git a/linden/indra/newview/skins/textures/textures.xml b/linden/indra/newview/skins/textures/textures.xml index ccf0834..72c6621 100644 --- a/linden/indra/newview/skins/textures/textures.xml +++ b/linden/indra/newview/skins/textures/textures.xml @@ -234,6 +234,8 @@ + + @@ -413,4 +415,7 @@ + + + diff --git a/linden/indra/newview/skins/xui/de/alerts.xml b/linden/indra/newview/skins/xui/de/alerts.xml index 6364ad9..054b313 100644 --- a/linden/indra/newview/skins/xui/de/alerts.xml +++ b/linden/indra/newview/skins/xui/de/alerts.xml @@ -2,7 +2,7 @@ - [ALERT_NAME] fehlt aus alerts.xml! + [ALERT_NAME] fehlt in alerts.xml! - Floater-Fehler: Folgende Steuerelemente konnten nicht gefunden werden: + Floater-Fehler: Folgende Steuerelemente wurden nicht gefunden: [CONTROLS] @@ -18,7 +18,7 @@ OK - + [MOTD] @@ -47,9 +47,9 @@ Verbindung mit [SECOND_LIFE] nicht möglich. -Das System ist evtl. ausgefallen. -Bitte versuchen Sie es in einigen Minuten wieder oder klicken Sie auf Hilfe, -um Rat und einen Link zur Systemstatus-Webpage zu erhalten. +Möglicherweise handelt es sich um einen Systemausfall. +Bitte versuchen Sie es in einigen Minuten erneut oder klicken Sie +für Unterstützung und einen Link auf die Systemstatus-Webseite auf 'Hilfe'. - + - Alle Änderungen an aktueller Kleidung/aktuellem Körperteil speichern? - - - - - - - - Alle Änderungen an aktueller Kleidung/aktuellem Körperteil speichern? + Änderung an aktueller Kleidung/Körperteil speichern? - Beim Hochladen des Texts für ein Skript trat aus folgendem Grund ein Fehler auf: [REASON]. Bitte versuchen Sie es später noch einmal. + Der Text für ein Skript konnte aus folgendem Grund nicht hochgeladen werden: [REASON]. Bitte versuchen Sie es erneut. - Beim Hochladen des kompilierten Skripts trat aus folgendem Grund ein Fehler auf: [REASON]. Bitte versuchen Sie es später noch einmal. + Eine kompiliertes Skript konnte aus folgendem Grund nicht hochgeladen werden: [REASON]. Bitte versuchen Sie es erneut. - Fehler beim Schreiben von Animationsdaten. + Fehler beim Schreiben von Animationsdaten. Bitte versuchen Sie es erneut. - Beim Hochladen der AuktionsFoto trat aus folgendem Grund ein Fehler auf: [REASON] + Eine Auktions-Screenshot konnte aus folgendem Grund nicht hochgeladen werden: [REASON] - Es kann nicht der Inhalt von mehr als einem Objekt gleichzeitig angezeigt werden. -Bitte wählen Sie nur ein Objekt und versuchen Sie es noch einmal. + Es kann nur jeweils der Inhalt von einem Objekt angezeigt werden. +Wählen Sie ein einzelnes Objekt aus und versuchen Sie es erneut. - Sie müssen ein Angebot für die Abstimmung angeben. -Geben Sie eine kurze Beschreibung des Zwecks der Gruppe ein. + Erstellen Sie eine Anfrage zur Abstimmung. +Geben Sie eine kurze Beschreibung der Gruppenziele sein. - Nicht genug Mittel. + Nicht genügend Geld. - Ein Foto Ihres Charakters wurde gespeichert. + Ein Foto Ihres Avatars wurde gespeichert. -Besuchen Sie das Webpage Studio-Exhibit, um sie zu sehen. +Sie finden es in der Webpage Studio-Ausstellung. - Alle Änderungen an Kleidung/Körperteilen speichern? + Änderung an Kleidung/Körperteilen speichern? - Granting modify rights to another resident allows them to change -ANY objects you may have in-world. Be VERY careful when handing -out this permission. -Do you want to grant modify rights for [FIRST_NAME] [LAST_NAME]? + Die Gewährung von Änderungsrechten an einen anderen Einwohner ermöglicht es diesem, +JEDES BELIEBIGE Objekt zu ändern, das Sie in der Second Life-Welt besitzen. Seien Sie SEHR vorsichtig, +wenn Sie diese Erlaubnis erteilen. +Möchten Sie [FIRST_NAME] [LAST_NAME] Änderungsrechte gewähren? - Do you want to revoke modify rights for [FIRST_NAME] [LAST_NAME]? + Möchten Sie [FIRST_NAME] [LAST_NAME] die Änderungsrechte entziehen? - Möchten Sie [FIRST] [LAST] wirklich von Ihren Freunden entfernen? + Möchten Sie [FIRST] [LAST] aus Ihrer Freundesliste entfernen? - Gruppe erfolgreich erstellt. + Gruppe wurde gegründet. - Gruppe kann nicht erstellt werden: + Gruppe konnte nicht erstellt werden. [MESSAGE] - Erstellen einer Gruppe kostet L$ [COST]. + Das Erstellen einer Gruppe kostet [COST] L$. -Um die Gruppe mehr als drei Tage beizubehalten, -müssen Sie insgesamt mindestens drei Mitglieder erreichen. +Damit die Gruppe länger als drei Tage bestehen bleibt, +muss sie aus mindestens zwei Mitgliedern bestehen. -Gruppe erstellen? +Gruppe gründen? - Erstellen einer Gruppe kostet L$ [COST]. -Sie haben nicht genug Geld, um diese Gruppe zu erstellen. + Das Erstellen einer Gruppe kostet [COST] L$. +Sie haben nicht genug L$, um eine Gruppe zu erstellen. - Gruppennamen müssen mindestens vier Buchstaben lang sein. + Ein Gruppenname muss mindestens vier Zeichen lang sein. - Der Gruppenname verwendet ein reserviertes Wort. Bitte -wählen Sie einen anderen Namen." + Der Gruppenname enthält ein unerwünschtes Wort. Bitte +wählen Sie einen anderen Namen. - Sie müssen einen Betreff angeben, um eine Gruppenmitteilung zu senden. + Geben Sie einen Betreff für die Gruppenmitteilung ein. - Sie müssen eine Charta für die Gruppe angeben. -Geben Sie eine kurze Beschreibung des Zwecks der Gruppe ein. + Schreiben Sie eine Gruppen-Charta. +Geben Sie eine kurze Beschreibung der Gruppenziele sein. - Sie fügen Gruppenmitglieder zur Rolle [ROLE_NAME] hinzu. -Mitglieder können von dieser Rolle nicht entfernt werden. -Die Mitglieder müssen selbst von dieser Rolle zurücktreten. -Möchten Sie wirklich fortfahren? + Sie sind im Begriff, Gruppenmitgliedern die Rolle [ROLE_NAME] zuzuweisen. +Diese Rolle kann Mitgliedern nicht mehr entzogen werden. +Sie müssen die Rolle selbst niederlegen. +Möchten Sie fortfahren? + + Beim Hinzufügen von Gruppenmitgliedern zur Eigentümerrolle + @@ -272,17 +261,17 @@ Möchten Sie wirklich fortfahren? - Sie fügen die Fähigkeit '[ACTION_NAME]' zur -Rolle '[ROLE_NAME]' hinzu. + Sie sind im Begriff, der Rolle '[ROLE_NAME]' die Fähigkeit +'[ACTION_NAME]' zuzuweisen. - *WARNUNG* - Jedes Mitglied in einer Rolle mit dieser Fähigkeit kann sich selbst -und alle anderen Mitglieder Rollen zuweisen, die mehr Macht haben, als -sie selbst derzeit haben, so dass sie sich potenziell -Eigentümer-gleiche Kräfte verleihen. Sie müssen sich dessen bewusst sein, bevor -Sie diese Fähigkeit zuweisen. + *ACHTUNG* + Mitglieder in einer Rolle mit dieser Fähigkeit können sich selbst - + und allen anderen Mitgliedern – Rollen zuweisen, die mehr Rechte + beinhalten als sie derzeit haben, und damit nahezu + Eigentümerrechte erreichen. Ãœberlegen Sie sich, wem Sie diese Fähigkeit + verleihen. -Diese Fähigkeit zu '[ROLE_NAME]' hinzufügen? +Der Rolle '[ROLE_NAME]' diese Fähigkeit zuweisen? - Sie fügen die Fähigkeit '[ACTION_NAME]' zur -Rolle '[ROLE_NAME]' hinzu. + Sie sind im Begriff, der Rolle '[ROLE_NAME]' die Fähigkeit +'[ACTION_NAME]' zuzuweisen. - *WARNUNG* - Jedes Mitglied in einer Rolle mit dieser Fähigkeit kann sich selbst -und alle anderen Mitglieder alle Fähigkeiten zuweisen und sich selbst -fast Eigentümer-gleiche Kräfte verleihen. + *ACHTUNG* + Mitglieder in einer Rolle mit dieser Fähigkeit können sich selbst - + und allen anderen Mitgliedern – alle Fähigkeiten zuweisen und + damit fast Eigentümerrechte erreichen. -Diese Fähigkeit zu '[ROLE_NAME]' hinzufügen? +Der Rolle '[ROLE_NAME]' diese Fähigkeit zuweisen? - Durch Auswahl der Option "Im Web veröffentlichen" können wir -Gruppenname, Insignien, Charta, Titel und Gründer auf der -[SECOND_LIFE]-Website veröffentlichen. Sie müssen angeben, ob einer der oben angegebenen -Inhalte gemäß der Community-Standards als Mature einzustufen -ist. + Im Web veröffentlichen - Durch Auswahl der Option "Im Web veröffentlichen" können wir -Name, Beschreibung, Foto und Position dieser Parzelle auf der -[SECOND_LIFE]-Website veröffentlichen. Sie müssen angeben, ob einer der oben angegebenen -Inhalte gemäß der Community-Standards als Mature einzustufen -ist. + In Suche veröffentlichen + + + + + Diese Parzelle kann nicht in der Suche angezeigt werden, da sie sich in +einer Region befindet, die das verbietet. - Durch Auswahl der Option "Im Web veröffentlichen" können wir -den [SECOND_LIFE]-Namen des Fotografen, die Betreffzelle, die Position, die Nachricht und die -Foto auf der [SECOND_LIFE]-Website veröffentlichen. Sie müssen angeben, ob einer der oben angegebenen -Inhalte für jede Foto gemäß der Community-Standards als Mature einzustufen -ist. + Im Web veröffentlichen - Durch Auswahl der Option "Im Web veröffentlichen" können wir -Ihren Namen, Ihr Bild und 'Info'-Text auf der [SECOND_LIFE]-Website veröffentlichen. + In Suche veröffentlichen + + + Auf der [SECOND_LIFE] Website können Sie anderen Einwohnern eine Partnerschaft vorschlagen und bestehende Partnerschaften lösen. + +Die Second Life Website für weitere Informationen über Partnerschaften öffnen? + + + + - If this resident has a web profile URL set then you can: - * Click Load to load the page with the embedded web browser. - * Click Open to view externally in your default web browser. + Wenn dieser Einwohner einen Webprofil-URL angegeben hat, können Sie: + * Auf 'Laden' klicken und die Seite im integrierten Browser anzeigen. + * Auf 'Öffnen' klicken und die Seite im externen Browser anzeigen. -When viewing your profile you can enter any URL as your Web Profile. -Residents can visit the URL you specify when they view your profile. +In Ihrem Profil können Sie jeden URL als Webprofil festlegen. +Bei Anzeige ihres Profils kann jeder Einwohner diesen URL öffnen. - If this resident has a web profile URL set then you can: - * Click Open to view externally in your default web browser. + Wenn dieser Einwohner einen Webprofil-URL angegeben hat, können Sie: + * Auf 'Öffnen' klicken und die Seite im externen Browser anzeigen. -When viewing your profile you can enter any URL as your Web Profile. -Residents can visit the URL you specify when they view your profile. +In Ihrem Profil können Sie jeden URL als Webprofil festlegen. +Bei Anzeige ihres Profils kann jeder Einwohner diesen URL öffnen. - Rufminimum größer als Maximum. -Entweder das Minimum senken oder das Maximum erhöhen. + Mindestreputation ist größer als Maximalwert. +Senken Sie den Mindestwert oder erhöhen Sie den Höchstwert. - Geldminimum größer als Maximum. -Entweder das Minimum senken oder das Maximum erhöhen. + Mindestbetrag ist größer als Höchstbetrag. +Senken Sie den Mindestbetrag oder erhöhen Sie den Höchstbetrag. - Funktionärstitel können max. 20 Zeichen lang sein. -Bitte wählen Sie einen kürzeren Titel. + Titel von Officern können maximal 20 Zeichen lang sein. +Wählen Sie einen kürzeren Titel. - Mitgliedstitel können max. 20 Zeichen lang sein. -Bitte wählen Sie einen kürzeren Titel. + Titel von Mitgliedern können maximal 20 Zeichen lang sein. +Wählen Sie einen kürzeren Titel. - Lokal ausführen... -Sie erhalten keine Daten. + Wird lokal ausgeführt... +Keine Daten. - Kein Mitglied ausgewählt, um es zu verjagen. + Kein Mitglied für Ausschluss ausgewählt. - Dadurch wird [MEMBER] aus der Gruppe ausgeschlossen. -Möchten Sie fortfahren? + [MEMBER] wird von der Gruppe ausgeschlossen. +Fortfahren? - Beitritt zu dieser Gruppe kostet L$ [COST]. -Möchten Sie fortfahren? + Der Beitritt zu dieser Gruppe kostet [COST] L$. +Fortfahren? - Beitritt zu dieser Gruppe kostet L$ [COST]. -Sie haben nicht genug Geld auf Ihrem Konto, um dieser Gruppe beizutreten. + Der Beitritt zu dieser Gruppe kostet [COST] L$. +Sie haben nicht genug Geld, um dieser Gruppe beizutreten. - Für L$ [COST] können Sie dieses Land ('[PARCEL_NAME]') -für [TIME] Stunden betreten. Pass kaufen? + Sie können dieses Land ('[PARCEL_NAME]') für [COST] L$ +[TIME] Stunden lang betreten. Pass kaufen? - Sie können keine Auktion für eine Parzelle starten, die -bereits zum Verkauf angeboten wird. Deaktivieren Sie den Landverkauf, wenn Sie -sich sicher sind, dass Sie eine Auktion starten möchten. + Eine Parzelle, die bereits zum Verkauf freigegeben +ist, kann nicht auktioniert werden. Brechen Sie zuerst den Landverkauf ab, +wenn Sie eine Auktion starten möchten. - Der Verkaufspreis muss auf > L$ 0 festgelegt werden, wenn Sie an jemanden verkaufen. -Bitte wählen Sie einen Käufer, wenn Sie für L$ 0 verkaufen. + Der Verkaufspreis muss beim allgemeinen Verkauf über 0 L$ liegen. +Wählen Sie eine bestimmte Person aus, wenn Sie für 0 L$ verkaufen. - Die ausgewählten [LAND_SIZE] m2 Land sind für den Verkauf bestimmt. -Ihr Verkaufspreis beträgt L$ [SALE_PRICE] und wird für den Verkauf an [NAME] autorisiert. - -Möchten Sie mit dieser Änderung fortfahren? + Die ausgewählten [LAND_SIZE] qm Land werden zum Verkauf freigegeben. +Der Verkaufspreis beträgt [SALE_PRICE] L$ und wird automatisch für den Verkauf an [NAME] autorisiert. - Möchten Sie wirklich alle Objekte, die mit der Gruppe -'[NAME]' auf dieser Parzelle Land gemeinsam verwendet werden, wieder in -das Inventar des vorherigen Eigentümers zurückführen? + Möchten Sie alle Ihre Objekte auf dieser Parzelle, +die der Gruppe '[NAME]' gehören, +zurück in das jeweilige Inventar ihrer vorherigen Eigentümer transferieren? -*WARNUNG* Dadurch werden die nicht transferierbaren Objekte, -die an die Gruppe übertragen wurden, gelöscht! +*WARNUNG* Alle nicht transferierbaren Objekte, die der +Gruppe übertragen wurden, werden dabei gelöscht! Objekte: [N] - Möchten Sie wirklich alle Objekte, die dem Einwohner -'[NAME]' auf dieser Parzelle Land gehören, wieder in sein -Inventar zurückführen? + Möchten Sie alle Objekte auf dieser Parzelle, +die NICHT dem Einwohner '[NAME]' gehören, +in das jeweilige Inventar ihrer Eigentümer transferieren? Objekte: [N] - Möchten Sie wirklich alle Objekte, die Ihnen auf -dieser Parzelle Land gehören, wieder in Ihr -Inventar zurückführen? + Möchten Sie alle Objekte +auf dieser Parzelle, die Ihnen gehören, zurück in Ihr Inventar +transferieren? Objekte: [N] - Möchten Sie wirklich alle Objekte auf dieser Parzelle Land, die NICHT -Ihnen gehören, wieder in das Inventar ihres Eigentümers zurückführen? -Ãœbertragbare Objekte, die an eine Gruppe übertragen wurden, -werden an ihre vorherigen Eigentümer zurückgegeben. + Möchten Sie alle Objekte auf dieser Parzelle, die NICHT +Ihnen gehören, in das Inventar ihrer Eigentümer transferieren? +Transferierbare Objekte, die an eine Gruppe übertragen wurden, +werden ihren vorherigen Eigentümern zurückgegeben. -*WARNUNG* Dadurch werden die nicht transferierbaren Objekte, -die an die Gruppe übertragen wurden, gelöscht! +*WARNUNG* Alle nicht transferierbaren Objekte, die der +Gruppe übertragen wurden, werden dabei gelöscht! Objekte: [N] - Möchten Sie wirklich alle Objekte auf dieser Parzelle Land, die NICHT -[NAME] gehören, wieder in das -Inventar ihres Eigentümers zurückführen? -Ãœbertragbare Objekte, die an eine Gruppe übertragen wurden, -werden an ihre vorherigen Eigentümer zurückgegeben. + Möchten Sie alle Objekte auf dieser Parzelle, die NICHT +[NAME] gehören, in das Inventar ihrer Eigentümer transferieren? +Transferierbare Objekte, die an eine Gruppe übertragen wurden, +werden ihren vorherigen Eigentümern zurückgegeben. -*WARNUNG* Dadurch werden die nicht transferierbaren Objekte, -die an die Gruppe übertragen wurden, gelöscht! +*WARNUNG* Alle nicht transferierbaren Objekte, die der +Gruppe übertragen wurden, werden dabei gelöscht! Objekte: [N] - Are you sure you want to return all objects -in this region back to their owner's inventory? + Möchten Sie alle aufgeführten Objekte ihren Eigentümern zurückgeben? - Are you sure you want to disable all objects in this region? + Möchten Sie alle Objekte in dieser Region deaktivieren? - Die Objekte auf dieser Parzelle, -die NICHT mit der Gruppe [NAME] geteilt werden, + Objekte auf dieser Parzelle, die von der +Gruppe [NAME] nicht gemeinsam genutzt werden, an ihre Eigentümer zurückgeben? Objekte: [N] - Deaktivierung externer Skripts nicht möglich. -Für diese gesamte Region ist Gesundheit aktiviert (nicht sicher). -Skriptausführung muss genehmigt sein, damit Schusswaffen funktionieren. + Skriptdeaktivierung nicht möglich. +Für die gesamte Region ist Schaden aktiviert. +Damit Waffen funktionieren, müssen Skripts erlaubt sein. - Sie müssen auf der Landparzelle stehen, + Sie müssen auf einer Landparzelle stehen, um ihren Landepunkt festzulegen. - Bitte geben Sie die E-Mail-Adresse des Empfängers ein. + Geben Sie die E-Mail-Adresse des Empfängers ein. - Bitte geben Sie Ihre E-Mail-Adresse ein. + Geben Sie Ihre E-Mail-Adresse ein. + + + Postkarte mit Standardbetreff bzw. -nachricht senden? + + + + - Fehler bei der Verarbeitung der Fotodaten + Fehler beim Verarbeiten der Fotodaten - Fehler bei der Verschlüsselung das Foto! + Fehler beim Erstellen des Fotos! - Beim Hochladen einer Postkarte trat aus folgendem Grund ein Fehler auf: [REASON] + Eine Postkarte konnte aus folgendem Grund nicht hochgeladen werden: [REASON] - Beim Hochladen eines Berichts trat aus folgendem Grund ein Fehler auf: [REASON] + Ein Report-Screenshot konnte aus folgendem Grund nicht hochgeladen werden: [REASON] - Sie müssen den Geschäftsbedingungen zustimmen, um sich weiter bei [SECOND_LIFE] anmelden zu können. + Bevor Sie sich in [SECOND_LIFE] anmelden können, müssen Sie den Nutzungsbedingungen zustimmen. - Konnte Outfit nicht anziehen." + Outfit konnte nicht angezogen werden. Der Outfit-Ordner enthält keine Kleidung, Körperteile oder Anhänge. - Kleidung oder Körperteile im Papierkorb können nicht getragen werden. + Kleider oder Körperteile im Papierkorb können nicht getragen werden - Dieses Objekt kann nicht getragen werden, da der komplette Informationssatz noch nicht verfügbar ist. Bitte versuchen Sie es etwas später noch einmal. + Sie können das Objekt nicht anziehen, weil es noch nicht geladen wurde. Warten Sie kurz und versuchen Sie es dann noch einmal. - Sie müssen einen Account haben, um eine Verbindung mit [SECOND_LIFE] herzustellen. + Sie benötigen ein Konto, um sich in [SECOND_LIFE] anmelden zu können. - - Sie müssen einen Account haben, um eine Verbindung mit [SECOND_LIFE] herzustellen. + Sie benötigen ein Konto, um sich in [SECOND_LIFE] anmelden zu können. -Zu www.secondlife.com, um einen neuen Account zu erstellen? +Möchten Sie auf www.secondlife.com ein Konto anlegen? - Anzeigen erscheinen eine Woche lang im Abschnitt 'Anzeigen' des Suchverzeichnisses. + Anzeigen erscheinen eine Woche lang auf der Registerkarte 'Anzeigen' im +Suchverzeichnis. -Füllen Sie Ihre Anzeige aus und klicken Sie auf 'Veröffentlichen...', um sie zum Verzeichnis hinzuzufügen. +Füllen Sie Ihre Anzeige aus und klicken Sie auf 'Veröffentlichen...', um sie zum +Verzeichnis hinzuzufügen. Sie werden gebeten, einen Preis zu bezahlen, wenn Sie auf 'Veröffentlichen' klicken. -Wenn Sie mehr bezahlen, erscheint Ihre Anzeige in der Liste und auch wenn Leute nach Suchbegriffen suchen weiter oben. +Wenn Sie mehr bezahlen erscheint Ihre Anzeige weiter oben in der Liste, ebenso wenn ein Benutzer nach Ihren Suchbegriffen sucht. + + Beim Hinzufügen einer neuen Anzeige + - Anzeige [NAME] löschen? -Bezahlte Gebühren werden nicht rückerstattet. + Anzeige '[NAME]' löschen? +Gebühren werden nicht rückerstattet. + + + + + Änderung an Anzeige [NAME] speichern? + + + - Einige Ihrer Anzeigeänderungen -erfordern, dass [SECOND_LIFE] abgeschaltet wird, -was dazu führt, dass alle nicht gespeicherten Daten verloren gehen. + Einige Änderungen an der Anzeige erfordern einen +sofortigen Neustart von [SECOND_LIFE], wodurch +alle laufenden Arbeiten verloren gehen. -Diese Änderungen übernehmen und beenden +Ãœbernehmen Sie die Änderungen und beenden Sie das Programm - Zur [SECOND_LIFE] Events-Webpage? + Zur [SECOND_LIFE] Events-Webseite? - Sie müssen einen Kandidaten auswählen, für den Sie stimmen. + Wählen Sie einen Kandidaten zum Abstimmen. - Bitte wählen Sie ein Objekt, das angezeigt wird. + Wählen Sie ein Angebot zur Ansicht. - Bitte wählen Sie ein Angebot, das angezeigt wird. + Wählen Sie ein Angebot zur Ansicht. - Bitte wählen Sie ein Verlaufsobjekt, das angezeigt wird. + Wählen Sie ein Element zur Ansicht. @@ -781,18 +799,40 @@ Diese Änderungen übernehmen und beenden Abbrechen + + + Alle 'Nächstes Mal zeigen'-Dialoge deaktivieren? + + + + - Cache-Speicherinhalt wird gelöscht, nachdem Sie [SECOND_LIFE] neu starten. + Der Cache wird nach einem Neustart von [SECOND_LIFE] gelöscht/geleert. + + + + + Der Cache wird nach einem Neustart von [SECOND_LIFE] verschoben. +Hinweis: Der Cache wird dabei gelöscht/geleert. + + + + + Die Port-Einstellungen werden nach einem Neustart von [SECOND_LIFE] wirksam. - Zur [SECOND_LIFE] Webpage, um Auktionsdetails anzuzeigen -oder ein Gebot zu machen? + Zur [SECOND_LIFE]-Webseite, um Auktionen anzuzeigen oder +ein Gebot abzugeben? - Es kann keine sichere Verbindung mit dem Login-Server hergestellt werden. -Das bedeutet oft, dass die Uhr Ihres Computers nicht richtig eingestellt ist. -Bitte gehen Sie zur Systemsteuerung und vergewissern Sie sich, dass Uhrzeit und Datum -richtig eingestellt sind. + Es konnte keine sichere Verbindung zum Anmeldeserver hergestellt werden. +Die Ursache hierfür ist oft eine falsch eingestellte Uhrzeit auf Ihrem Computer. +Bitte vergewissern Sie sich, dass Datum und Uhrzeit korrekt eingestellt sind. -Wenn weiterhin dieser Fehler angezeigt wird, gehen Sie -zum Support-Abschnitt der Website SecondLife.com -und melden Sie das Problem. +Bitte melden Sie das Problem unter +www.secondlife.com/support, +sollte der Fehler wiederholt auftreten. Verbindung mit [SECOND_LIFE] nicht möglich. -Der Login-Server konnte sich selbst nicht über SSL verifizieren. -Wenn weiterhin dieser Fehler angezeigt wird, gehen Sie -zum Support-Abschnitt der Website SecondLife.com -und melden Sie das Problem. +Der Anmeldeserver konnte sich nicht per SSL verifizieren. +Bitte melden Sie das Problem unter +www.secondlife.com/support, +sollte der Fehler häufiger auftreten. Verbindung mit [SECOND_LIFE] nicht möglich. -Trotz unserer besten Bemühungen ist etwas schief gegangen. -Bitte gehen Sie zum Support-Abschnitt der Website SecondLife.com -und melden Sie das Problem. Falls möglich, schließen Sie Ihre SecondLife.log-Datei -ein aus: C:\Dokumente\(Name)\Anwendungsdaten\SecondLife\logs -Vielen Dank! +Trotz all unserer Bemühungen ist ein unerwarteter Fehler aufgetreten. +Bitte melden Sie das Problem auf +www.secondlife.com/support und fügen Sie dem Bericht die Datei SecondLife.log +an, die Sie hier finden: C:\Dokumente und Einstellungen\(Name)\Anwendungsdaten\SecondLife\logs +Vielen Dank. Verbindung mit [SECOND_LIFE] nicht möglich. -Trotz unserer besten Bemühungen ist etwas schief gegangen. -Bitte gehen Sie zum Support-Abschnitt der Website SecondLife.com -und melden Sie das Problem. Falls möglich, schließen Sie Ihre SecondLife.log-Datei -ein aus: ~/Library/Application Support/SecondLife/logs -Vielen Dank! +Trotz all unserer Bemühungen ist ein unerwarteter Fehler aufgetreten. +Bitte melden Sie das Problem auf +www.secondlife.com/support und fügen Sie dem Bericht die Datei SecondLife.log +an, die Sie hier finden: ~/Library/Application Support/SecondLife/logs +Vielen Dank. - Bei der Bearbeitung Ihres Login-Authentifizierungs-Tokens -gab es ein Problem. Bitte versuchen Sie noch einmal, -sich anzumelden. Wenn weiterhin dieser Fehler angezeigt wird, -gehen Sie zum Support-Abschnitt der -Website SecondLife.com. + Bei der Prüfung Ihres Authentifizierungs- +Token ist ein Problem aufgetreten. Bitte melden Sie sich +erneut an. Wenden Sie sich an www.secondlife.com/support, +sollte dieser Fehler wiederholt auftreten. - Unbekanntes Problem beim Verbindungsversuch. -(Leere Fehlermeldung vom Server.) + Unbekanntes Verbindungsproblem. -Bitte versuchen Sie es in einigen Minuten wieder oder klicken Sie auf Hilfe, -um Rat und einen Link zur Systemstatus-Webpage zu erhalten. +Bitte versuchen Sie es in einigen Minuten erneut oder klicken Sie +für Unterstützung und einen Link auf die Systemstatus-Webseite auf 'Hilfe'. - Verbindung nicht möglich. Keine Antwort von Login-Datenbank. + Verbindung nicht möglich. Keine Anmeldebestätigung von Simulator. -Bitte versuchen Sie es in einigen Minuten wieder oder klicken Sie auf Hilfe, -um Rat und einen Link zur Systemstatus-Webpage zu erhalten. +Bitte versuchen Sie es in einigen Minuten erneut oder klicken Sie +für Unterstützung und einen Link zur Systemstatus-Webseite auf 'Hilfe'. - Anmeldungs-Timeout beim Warten auf Ihre Position in der Welt. Bitte versuchen Sie es noch einmal. + Anmeldezeit überschritten. Ihre Position konnte nicht ermittelt werden. Bitte versuchen Sie es erneut. - [SECOND_LIFE] Installation ist abgeschlossen. + Die Installation von [SECOND_LIFE] ist abgeschlossen. -Falls Sie [SECOND_LIFE] zum ersten Mal verwenden, müssen Sie -einen Account erstellen, bevor Sie sich anmelden können. +Wenn Sie [SECOND_LIFE] das erste Mal verwenden, müssen Sie ein Konto anlegen, +bevor Sie sich anmelden können. -Zu www.secondlife.com zurückkehren, um einen neuen Account zu erstellen? +Möchten Sie auf www.secondlife.com ein Konto erstellen? - Ihre Kleidung wird noch heruntergeladen. -Sie können die Welt normal verwenden und andere Benutzer -sehen Sie korrekt. + Ihr Avatar wird noch heruntergeladen. +Sie können [SECOND_LIFE] normal verwenden und andere +Einwohner können Sie sehen. - Verbindung mit Server nicht möglich. -Konnte Domainnamen nicht auflösen: [DOMAIN] + Verbindung zum Server nicht möglich. +Folgende Domäne konnte nicht aufgelöst werden: [DOMAIN] Bitte überprüfen Sie Ihre Netzwerkverbindung. - Verbindung nicht möglich. Login-Server hat Login-Paket + Verbindung nicht möglich. Anmeldeserver hat das Anmeldepaket nie erhalten. -Bitte versuchen Sie es in einigen Minuten wieder oder klicken Sie auf Hilfe, -um Rat und einen Link zur Systemstatus-Webpage zu erhalten. +Bitte versuchen Sie es in einigen Minuten erneut oder klicken Sie +für Unterstützung und einen Link auf die Systemstatus-Webseite auf 'Hilfe'. + + + Besuchen Sie das [SECOND_LIFE] QA-Wiki. + + + Beim Starten eines Browsers, um das QA-Wiki anzuzeigen + + + + + + + Es gibt Probleme beim Hinzufügen eines neuen Grundstücksverwalters. Bei mindestens einem Grundstück ist die Verwalterliste voll. + + + + + Wenn Sie diese Option auswählen, können Parzelleneigentümer ihre Parzellen nicht in der Suche anzeigen lassen +Standard: aus + + + + + Dieses Kontrollkästchen zeigt Folgendes an: +- diese Parzelle in den Suchergebnissen +- die öffentlichen Objekte dieser Parzelle + + + + + Die Parzellen auf diesem Grundstück können über eigene Voice- + Channel verfügen, die es Einwohnern ermöglichen, sich mit + anderen Personen in der Nähe zu unterhalten. + + Standard: aus + + + + + Diese Version von Second ist mit dem Voice-Chat-Feature in dieser Region nicht kompatibel. Damit Voice-Chat funktioniert, müssen Sie Second Life aktualisieren. + + - Möchten Sie wirklich beenden? + Wirklich beenden? + + Beim Beenden von Second Life. + + + Die Region [REGION] erlaubt kein Terraforming. -Sie müssen Land in einem anderen Teil der Welt kaufen, -um es zu terraformen. - Sie haben keine Berechtigung, dieses Objekt zu kopieren -und werden es aus Ihrem -Inventar verlieren, wenn Sie es hergeben. Möchten Sie -dieses Objekt wirklich anbieten? + Sie sind nicht berechtigt, dieses +Objekt zu kopieren und verlieren es +aus Ihrem Inventar, wenn Sie es weggeben. Möchten +Sie dieses Objekt anbieten? - Inventarobjekt kann nicht angegeben werden. + Inventarobjekt kann nicht übergeben werden. @@ -1169,20 +1268,21 @@ dieses Objekt wirklich anbieten? - So viele Objekte können nicht in einem einzigen Inventartransfer übergeben werden. + Es können maximal 42 Objekte auf einmal in das Inventar transferiert werden. - Keine Objekte, die Sie geben können. + Sie sind nicht berechtigt, die ausgewählten + Objekte zu kopieren. - Sie haben keine Berechtigung, [COUNT] -ausgewählte Objekte zu kopieren. Sie werden diese Objekte -aus Ihrem Inventar verlieren. -Möchten Sie diese Objekte wirklich hergeben? + Sie sind nicht berechtigt, [COUNT] der ausgewählten +Objekte zu kopieren. Diese Objekte werden aus +Ihrem Inventar gelöscht. +Möchten Sie diese Objekte weggeben? - Inventarkategorie kann nicht angegeben werden. + Sie sind nicht berechtigt, die ausgewählten + Ordner zu kopieren. Diesen Avatar einfrieren? -Er kann sich dann temporär nicht bewegen, -kann nicht chatten oder mit der Welt interagieren. +Der Avatar wird außer Gefecht gesetzt und kann +sich nicht mehr bewegen, chatten oder mit der Welt interagieren. - Diesen Avatar von Ihrem Land werfen? + Diesen Avatar aus Ihrem Land werfen? - Keine gültige uuid + Ungültige UUID. - ERWERBSFEHLER: Zu viele Objekte ausgewählt. + FEHLER: Zu viele Objekte ausgewählt. - ERWERBSFEHLER: Objekte erstrecken sich über mehr als eine Region. -Bitte verschieben Sie alle zu erwerbenden Objekte in die gleiche Region. + FEHLER: Die Objekte überspannen mehrere Regionen. +Verschieben Sie alle betreffenden Objekte in dieselbe +Region. Mindestens ein Objekt ist gesperrt oder gehört nicht Ihnen. Wenn Ihnen ein Objekt nicht gehört und Sie es nehmen, -werden die Berechtigungen des nächsten Eigentümers darauf angewendet und -Sie können es in Zukunft evtl. nicht ändern oder -kopieren. -Sie können die aktuelle Auswahl trotzdem nehmen. -Möchten Sie diese Objekte wirklich nehmen? +werden die Rechte für den nächsten Eigentümer angewandt und Sie +können es möglicherweise nicht bearbeiten oder kopieren. + +Möchten Sie diese Objekte nehmen? @@ -1264,10 +1365,10 @@ Möchten Sie diese Objekte wirklich nehmen? [EXTRA] -Zu [URL], um Informationen zur Kaufswährung anzuzeigen? +[URL] für Informationen zum Deviseneinkauf öffnen? - Verknüpfen dieser [COUNT] Objekte nicht möglich. + Verknüpfung dieser [COUNT] Objekte nicht möglich. Sie können maximal [MAX] Objekte verknüpfen. -Versuchen Sie, weniger Objekte auszuwählen. - Sie können nur komplette Objektsätze verknüpfen und müssen -mehr als ein Objekt auswählen. + Sie können nur vollständige Objektsätze verknüpfen und +Sie müssen mehr als ein Objekt auswählen. - Verknüpfen nicht möglich, weil Sie keine Änderungsberechtigung -für alle Objekte haben. Vergewissern Sie sich, dass keine gesperrt sind und -alle Ihnen gehören. + Verknüpfung nicht möglich, da Sie nicht alle Objekte bearbeiten +dürfen. Stellen Sie sicher, dass kein Objekt gesperrt ist +und alle Objekte Ihnen gehören. - Verknüpfen nicht möglich, weil nicht alle Objekte den gleichen -Eigentümer haben. Vergewissern Sie sich, dass alle ausgewählten Objekte Ihnen gehören. + Verknüpfung nicht möglich, da nicht alle Objekte denselben +Eigentümer haben. Stellen Sie sicher, dass alle ausgewählten Objekte Ihnen gehören. - Keine Dateierweiterung für die Datei: '[FILE]' -Bitte vergewissern Sie sich, dass die Datei eine korrekte Dateierweiterung hat. + Keine Datei-Erweiterung für Datei: '[FILE]' +Vergewissern Sie sich, dass die Datei die richtige Datei-Erweiterung hat - Ungültige Dateierweiterung [EXTENSION] -[VALIDS] erwartet + Ungültige Datei-Endung [EXTENSION] +Erwartet wurde [VALIDS] - Konnte die offene Upload-Audiodatei nicht zum Lesen öffnen: + Sounddatei konnte nicht hochgeladen werden: [FILE] - Datei ist anscheinend keine RIFF WAVE-Datei: + Die Datei ist anscheinend keine RIFF WAVE-Datei: [FILE] - Datei ist anscheinend keine PCM WAVE-Audiodatei: + Die Datei ist anscheinend keine PCM WAVE-Audiodatei: [FILE] - Datei hat ungültige Anzahl von Kanälen (muss mono oder stereo sein): + Die Datei hat eine ungültige Anzahl Tonkanäle (muss Mono oder Stereo sein): [FILE] - Datei hat anscheinend nicht die unterstützte Sample-Rate (muss 44,1k betragen): + Die Sample-Rate dieser Datei wird nicht unterstützt (muss 44,1 K sein): [FILE] - Datei hat anscheinend nicht die unterstützte Wortgröße (muss 8 oder 16 Bit betragen): + Die Word-Größe dieser Datei wird nicht unterstützt (muss 8 oder 16 Bit sein): [FILE] - Konnte Daten-Masse nicht in WAV-Header finden: + 'Daten'-Chunk in WAV-Header nicht gefunden: [FILE] @@ -1364,19 +1464,19 @@ Bitte vergewissern Sie sich, dass die Datei eine korrekte Dateierweiterung hat. - Problem mit Datei [FILEI]: + Problem mit Datei [FILE]: [ERROR] - Konnte die temporäre komprimierte Audiodatei nicht zum Schreiben öffnen: [FILE] + Temporäre komprimierte Sounddatei konnte nicht geöffnet werden: [FILE] - Unbekannter vorbis-Verschlüsselungsfehler bei [FILE] + Unbekannter Vorbis-Kodierungsfehler in: [FILE] @@ -1386,106 +1486,101 @@ Bitte vergewissern Sie sich, dass die Datei eine korrekte Dateierweiterung hat. - Unbekannte Linden-Ressourcendateiversion in Datei: [FILE] + Unbekannte Linden-Ressourcenversion in Datei: [FILE] - Erstellen der Ausgabedatei nicht möglich: [FILE] + Ausgabedatei konnte nicht erstellt werden: [FILE] - Wir unterstützen derzeit keinen Mehrfach-upload von Animationsdateien. + Der Mehrfach-Upload von Animationsdateien wird zurzeit nicht unterstützt. - Zugriff auf Ausgabedatei nicht möglich: [FILE] + Kein Zugriff auf Ausgabedatei: [FILE] - Nicht genug Mittel, um die Datei hochzuladen: Die Kosten betragen L$ [COST], der Kontostand ist L$ [BALANCE]. + Nicht genügend L$, um Datei hochzuladen: Hochladen kostet [COST] L$, Sie haben [BALANCE] L$ - Nicht genug Mittel, um das Hochladen von [FILE] abzuschließen: Die Kosten betragen L$ [COST], der Kontostand ist L$ [BALANCE]. + Nicht genügend L$, um [FILE] hochzuladen: Hochladen kostet [COST] L$, Sie haben [BALANCE] L$ - [FILE] kann aus folgendem Grund nicht hochgeladen werden: [REASON] -Bitte versuchen Sie es später noch einmal. + Datei [FILE] kann aus folgendem Grund nicht hochgeladen werden: [REASON] +Bitte versuchen Sie es erneut. - Sie können hier kein Landmarken erstellen, weil -der Eigentümer des Landes dies nicht zulässt. -Versuchen Sie es zunächst einige Meter entfernt. + Sie können hier keine Landmarke erstellen, +da der Landeigentümer dies verboten hat. - Rekompilierung kann nicht durchgeführt werden. -Objekte mit Skripts auswählen, die -gültig sind. + 'Rekompilieren' nicht möglich. +Objekt mit Skript wählen. - Rekompilierung kann nicht durchgeführt werden. -Objekte mit Skripts auswählen, die -Sie ändern dürfen. + 'Rekompilieren' nicht möglich. +Wählen Sie Objekte mit Skripts, die +Sie bearbeiten dürfen. - Zurücksetzen kann nicht durchgeführt werden. -Objekte mit Skripts auswählen, die -gültig sind. + 'Zurücksetzen' nicht möglich. +Wählen Sie Objekte mit Skripts. - Zurücksetzen kann nicht durchgeführt werden. -Objekte mit Skripts auswählen, die -Sie ändern dürfen. + 'Zurücksetzen' nicht möglich. +Wählen Sie Objekte mit Skripts, die +Sie bearbeiten dürfen. - Skripts können nicht auf 'ausgeführt' eingestellt werden. -Objekte mit Skripts auswählen, die -gültig sind. + 'Ausführen' von Skripts nicht möglich. +Wählen Sie Objekte mit Skripts. - Skripts können nicht auf 'ausgeführt' eingestellt werden. -Objekte mit Skripts auswählen, die -Sie ändern dürfen. + 'Ausführen' von Skripts nicht möglich. +Wählen Sie Objekte mit Skripts, die +Sie bearbeiten dürfen. - Skripts können nicht auf 'nicht ausgeführt' eingestellt werden. -Objekte mit Skripts auswählen, die -gültig sind. + 'Deaktivieren' von Skripts nicht möglich. +Wählen Sie Objekte mit Skripts. - Skripts können nicht auf 'nicht ausgeführt' eingestellt werden. -Objekte mit Skripts auswählen, die -Sie ändern dürfen. + 'Deaktivieren' von Skripts nicht möglich. +Wählen Sie Objekte mit Skripts, die +Sie bearbeiten dürfen. - Kein vorderster Floater zu speichern + Kein vorderster Floater zum Speichern. @@ -1505,12 +1600,12 @@ Sie ändern dürfen. - Objektimport fehlgeschlagen. Datei konnte nicht übertragen werden. + Objektimport fehlgeschlagen. Datei konnte nicht geladen werden. - Objektimport fehlgeschlagen. Datei ist nicht im akzeptablen SLObject-Format. + Objektimport fehlgeschlagen. Datei liegt nicht im Format SLObject vor. @@ -1520,30 +1615,30 @@ Sie ändern dürfen. - Teleport nicht möglich. + Teleport fehlgeschlagen. [REASON] Landeigentümer kann nicht festgelegt werden: -Nichts ausgewählt. +Keine Parzelle ausgewählt. - Erzwingen von Landeigentum nicht möglich, weil Auswahl mehrere -Regionen überspannt. Bitte wählen Sie eine kleinere Fläche und versuchen Sie es noch einmal. + Eine erzwungene Landübertragung ist nicht möglich, da die Auswahl +mehrere Regionen umfasst. Wählen Sie ein kleineres Gebiet und versuchen Sie es erneut. - Diese Parzelle steht zur Auktion. Durch Erzwingen des Eigentums wird -die Auktion abgebrochen und einige Einwohner sind evtl. -darüber nicht glücklich, wenn die Gebotsabgabe begonnen hat. Eigentum erzwingen? + Diese Parzelle steht zur Auktion. Eine zwangsweise Eigentumsübertragung +beendet die Auktion und verärgert womöglich Einwohner, +die bereits ein Gebot abgegeben haben. Eigentumsübertragung erzwingen? - Inhaltsbildung nicht möglich: -Nichts ausgewählt. + Inhaltsidentifizierung nicht möglich: +Keine Parzelle ausgewählt. - Inhaltsbildung nicht möglich: -Keine Region. + Inhaltsidentifizierung nicht möglich: +Keine Region ausgewählt. Land kann nicht aufgegeben werden: -Nichts ausgewählt. +Keine Parzelle ausgewählt. Land kann nicht aufgegeben werden: -Kann Region nicht finden. +Region nicht gefunden. Land kann nicht gekauft werden: -Nichts ausgewählt. +Keine Parzelle ausgewählt. @@ -1588,46 +1683,46 @@ Kann die Region nicht finden, in der sich dieses Land befindet. Land kann nicht übertragen werden: -Nichts ausgewählt. +Keine Parzelle ausgewählt. Land kann nicht übertragen werden: -Keine Gruppe. +Keine Gruppe ausgewählt. Land kann nicht übertragen werden: Kann die Region nicht finden, in der sich dieses Land befindet. -Verwenden Sie Hilfe -> Bug melden, um dies zu melden. +Bitte melden Sie dies über 'Hilfe' -> 'Fehler melden'. Landeigentümer kann nicht festgelegt werden: -Nichts ausgewählt. +Keine Parzelle ausgewählt. - Landkauf nicht möglich, weil Auswahl mehrere Regionen überspannt. -Bitte wählen Sie eine kleinere Fläche und versuchen Sie es noch einmal. + Landkauf nicht möglich, da die Auswahl mehrere Regionen umfasst. +Wählen Sie ein kleineres Gebiet und versuchen Sie es erneut. Land kann nicht gekauft werden: -Mehrere verschiedene Parzellen ausgewählt. -Versuchen Sie, eine kleinere Fläche auszuwählen. +Mehrere Parzellen ausgewählt. +Wählen Sie eine einzelne Parzelle. Land kann nicht übertragen werden: -Mehrere verschiedene Parzellen ausgewählt. -Versuchen Sie, eine kleinere Fläche auszuwählen. +Mehrere Parzellen ausgewählt. +Wählen Sie eine einzelne Parzelle. @@ -1637,15 +1732,15 @@ Versuchen Sie, eine kleinere Fläche auszuwählen. - Diese Position kann Streaming-Musik abspielen. + Dieser Ort kann Streaming-Musik wiedergeben. -Musik erfordert eine Internetverbindung mit einer -Geschwindigkeit von mind. 768 kb/s. +Musik erfordert eine Internetverbindung +mit mindestens 768 kbit/s. -Musik abspielen, wenn verfügbar? +Musik wiedergeben, wenn verfügbar? - Diese Position kann Streaming-Video abspielen. + Dieser Ort kann Streaming-Video wiedergeben. -Streaming-Video erfordert eine Internetverbindung mit einer -Geschwindigkeit von mind. 768 kb/s. +Streaming-Video erfordert eine Internetverbindung +mit mindestens 768 kbit/s. -Streaming-Video abspielen, wenn verfügbar? +Streaming-Video wiedergeben, wenn verfügbar? (Sie können diese Option später unter -'Einstellungen' > 'Audio & Video' ändern). +'Einstellungen' > 'Audio & Video' ändern.) - + - Ihr [VENDOR_LABLE] [CARD_NAME]-Grafiktreiber auf diesem Computer ist veraltet. - -Dies ist die Software, die Ihre Videokarte steuert. -Alte Treiber können dazu führen, dass 3D-Grafikprogramme wie [SECOND_LIFE] langsam ausgeführt werden oder abstürzen. - -Wir empfehlen dringend, dass Sie auf den neuesten [DRIVER_NAME]-Treiber aktualisieren, der von [VENDOR_LABEL] kostenlos heruntergeladen werden kann. - -Zur [SECOND_LIFE] Treiber-Webpage? + Zu www.secondlife.com, um Ihr Konto zu verwalten? + + Beim Starten eines Browsers, um Ihr Konto zu verwalten + + + + + + + Informieren Sie sich im [SECOND_LIFE] Wiki, wie man Fehler richtig meldet. + + + Beim Starten eines Browsers, um das Fehlermeldungs-Wiki anzuzeigen + - + - Ihr Intel Extreme-Grafiktreiber auf diesem Computer ist veraltet. - -Dies ist die Software, die Ihre Videokarte steuert. -Alte Treiber können dazu führen, dass 3D-Grafikprogramme wie [SECOND_LIFE] langsam ausgeführt werden oder abstürzen. - -Wir empfehlen dringend, dass Sie auf den neuesten Treiber aktualisieren, der von Intel kostenlos heruntergeladen werden kann. - -Zur [SECOND_LIFE] Treiber-Webpage? + Informieren Sie sich im [SECOND_LIFE] Wiki, wie man Sicherheitsprobleme richtig meldet. + + Beim Starten eines Browsers, um das Sicherheitsfragen-Wiki anzuzeigen + - + - GL zeigt an, dass der Grafiktreiber dieses Systems im PCI-Modus ausgeführt -wird, einer langsameren Methode zur Grafikerstellung. Wenn Sie eine PCI-Videokarte verwenden, -können Sie diese Meldung ignorieren. Wenn Sie eine AGP-Videokarte verwenden, sollten Sie -Ihre Motherboard-Treiber aktualisieren, um in dieser und anderen 3D-Anwendungen -bessere Leistungen zu erzielen. Wenn Sie eine PCI Express-Videokarte verwenden, können Sie -AGP Graphics Acceleration über das Optionen-Feld in 'Einstellungen' in [SECOND_LIFE] aktivieren. + Im [SECOND_LIFE] Allgemeine-Fragen-Tracker können Sie Fehler und andere Probleme melden. + + Beim Starten eines Browsers, um den Allgemeine Probleme Tracker anzuzeigen + + + - + - Zu www.secondlife.com, um Ihren Account zu verwalten? + Informieren Sie sich im [SECOND_LIFE] Wiki über den Allgemeine Fragen-Tracker. - - Suchen Sie in der [SECOND_LIFE] Knowledge Base nach den neuesten Tipps und Tricks. + Durchsuchen Sie die [SECOND_LIFE] Knowledge Base nach aktuellen Tipps und Tricks. + + Beim Starten eines Browsers, um die Knowledge Base anzuzeigen + - Contact [SECOND_LIFE] Support. + Wenden Sie sich an den Support von [SECOND_LIFE]. + + Beim Starten eines Browsers, um den Support zu kontaktieren + - Im offiziellen Linden Blog finden Sie die neuesten Nachrichten und Informationen. + Im offiziellen Linden-Blog finden Sie die neuesten Nachrichten und Informationen. + + Beim Starten eines Browsers, um das Blog anzuzeigen + - Zur LSL-Anleitung, um Scripting-Hilfe zu erhalten? + Zur Scripting-Anleitung, um Scripting-Hilfe zu erhalten? + + Beim Starten eines Browsers, um die Scripting-Anleitung anzuzeigen + - Zur LSL-Wiki, um Scripting-Hilfe zu erhalten? + Zum LSL-Portal, um Scripting-Hilfe zu erhalten? + + Beim Starten eines Browsers, um das LSL-Portal anzuzeigen + - [SECOND_LIFE]-Versionshinweise anzeigen? + Die Release-Hinweise von [SECOND_LIFE] anzeigen? + + Beim Starten eines Browsers, um die Versionshinweise anzuzeigen + - Möchten Sie wirklich die ausgewählten Objekte -an ihre Eigentümer zurückgeben? Transferierbare übertragene Objekte werden an ihre vorherigen Eigentümer zurückgegeben. -(Alle Objekte werden in den Ordner zurückgegeben, in dem sie sich zuletzt befanden.) + Möchten Sie die ausgewählten Objekte +an ihre Eigentümer zurückgeben? Transferierbare übertragene +Objekte werden ihren früheren Eigentümern zurückgegeben. -"*WARNUNG* Nichttransferierbare übertragene Objekte werden gelöscht! +*WARNUNG* Nicht transferierbare übertragene Objekte werden dabei gelöscht! + + Beim Zurückgeben von Objekten an ihre Eigentümer + - Second Life-Versionshinweise anzeigen? + Die Release-Hinweise von Second Life anzeigen? + + Beim Anzeigen der Versionshinweise + - Sie sind derzeit Funktionär der Gruppe [GROUP]. -Gruppe verlassen? + Sie sind Officer der Gruppe [GROUP]. +Diese Gruppe verlassen? - Sie sind derzeit Mitglied der Gruppe [GROUP]. -Gruppe verlassen? + Sie sind Mitglied der Gruppe [GROUP]. +Diese Gruppe verlassen? - Möchten Sie WIRKLICH alle Benutzer vom Raster jagen? + Möchten Sie WIRKLICH alle Benutzer aus dem Grid werfen? + + - Leider können Sie Linden nicht stummschalten. + Linden können nicht stummgeschaltet werden. - Nur nach Namen stummschalten wirkt sich nur auf Objekt-Chat und IM aus, nicht auf Töne. -Sie müssen den Namen des Objekts genau eingeben. + Stummschalten nach Name betrifft nur Chat und IM, keine Sounds. +Sie müssen den Objektnamen exakt angeben. Objektname @@ -2913,7 +3049,7 @@ Sie müssen den Namen des Objekts genau eingeben. - Sie haben diesen Namen bereits stummgeschaltet. + Dieser Name ist bereits stummgeschaltet. - Obwohl zulässig, kann das Löschen von Inventar das Objekt -beschädigen. Möchten Sie dieses Inventarobjekt löschen? + Diese Aktion ist zwar erlaubt, aber beim Löschen von +Inhalten wird das Objekt beschädigt. Möchten Sie dieses Element löschen? - Eigentümer dieses Objekts kann nicht beurteilt werden, Objekt ist Eigentum einer Gruppe. + Der Eigentümer dieses Objekts kann nicht bewertet werden. Das Objekt befindet sich in Gruppeneigentum. - Derzeit kann keine Visitenkarte angeboten werden. Bitte versuchen Sie es etwas später noch einmal. + Sie können gerade keine Visitenkarte übergeben. Warten Sie kurz und versuchen Sie es dann noch einmal. - Derzeit kann keine Freundschaft angeboten werden. Bitte versuchen Sie es etwas später noch einmal. + Sie können gerade keine Freundschaft anbieten. Warten Sie kurz und versuchen Sie es dann noch einmal. - Zuhause kann nicht auf hier eingestellt werden. -Ihr Zuhause muss auf Land liegen, das Ihnen oder Ihrer Gruppe gehört. + Aktuelle Position kann nicht als Zuhause gewählt werden. - Belegt-Modus eingestellt. -Chat und Instant Messages werden ausgeblendet. Instant Messages erhalten Ihre Belegt-Antwort. Alle Teleport- + Beschäftigt-Modus aktiviert. +Chat und Instant Messages werden ausgeblendet. Instant +Messages erhalten Ihre Beschäftigt-Antwort. Alle Teleport- und Inventarangebote werden abgelehnt. + + Beim Aktivieren des Beschäftigt-Modus + - Kein Player vs. Player (PvP)-Missbrauch festgestellt + Kein Player vs. Player (PvP-) Missbrauch festgestellt - Nur Objekte mit unbeschränkten Berechtigungen für 'nächster Eigentümer' -können an Grußkarten angehängt werden. + An Notizkarten lassen sich nur Objekte mit uneingeschränkten +'Nächster Eigentümer'-Rechten anfügen. - Sie sind Mitglied zu vieler Gruppen, um einer -weiteren beizutreten. Bitte verlassen Sie mindestens eine Gruppe, -bevor Sie dieser beitreten, oder lehnen Sie das Angebot ab. -Um eine Gruppe zu verlassen wählen Sie die Option 'Meine Gruppen'... -im Menü 'Bearbeiten'. -[NAME] hat Sie eingeladen, Mitglied einer Gruppe zu werden. + Sie sind bereits in zu vielen Gruppen Mitglied +und können keiner weiteren beitreten. Bitte verlassen Sie eine Gruppe, +bevor Sie dieser beitreten oder lehnen Sie das Angebot ab. +Die Option zum Austritt aus einer Gruppe finden Sie unter +'Bearbeiten' > 'Gruppen...'. +[NAME] hat Sie eingeladen, einer Gruppe beizutreten. [INVITE] - Sie sind Mitglied zu vieler Gruppen, um einer -weiteren beizutreten. Bitte verlassen Sie mindestens eine Gruppe, -bevor Sie dieser beitreten, oder lehnen Sie das Angebot ab. -Um eine Gruppe zu verlassen wählen Sie die Option 'Meine Gruppen'... -im Menü 'Bearbeiten'. -[NAME] hat Sie eingeladen, einer Gruppe als Funktionär beizutreten. + Sie sind bereits in zu vielen Gruppen Mitglied +und können keiner weiteren beitreten. Bitte verlassen Sie eine Gruppe, +bevor Sie dieser beitreten oder lehnen Sie das Angebot ab. +Die Option zum Austritt aus einer Gruppe finden Sie unter +'Bearbeiten' > 'Gruppen...'. +[NAME] hat Sie eingeladen, einer Gruppe als Officer beizutreten. [INVITE] - Diesen Benutzer mit welcher Meldung verjagen? + Beim Hinauswerfen dieses Benutzers welche Meldung anzeigen? - Ein Administrator hat Sie abgemeldet. + Sie wurden von einem Administrator abgemeldet. - Alle derzeit im Raster befindlichen Benutzer mit welcher Meldung verjagen? + Beim Hinauswerfen aller Personen vom Grid welche Meldung anzeigen? - Ein Administrator hat Sie abgemeldet. + Sie wurden von einem Administrator abgemeldet. - Diesen Benutzer mit welcher Meldung einfrieren? + Beim Einfrieren dieses Benutzers welche Meldung anzeigen? - Sie wurden eingefroren. Sie können sich nicht bewegen und nicht chatten. Ein Administrator wird Sie per Instant Message (IM) kontaktieren. + Sie wurden eingefroren. Bewegen oder Chatten ist nicht mehr möglich. Ein Administrator wird sich über IM an Sie wenden - Diesen Benutzer mit welcher Meldung auftauen? + Beim Auftauen dieses Benutzers welche Meldung anzeigen? Sie sind nicht mehr eingefroren. @@ -3083,7 +3222,7 @@ im Menü 'Bearbeiten'. - Geben Sie die Makler-ID eines Benutzers ein, um ihn auszustreichen. + Geben Sie die Avatar-ID des zu entfernenden Benutzers ein - Gott Benutzer an Ihre Position rufen lassen? + Benutzer an Ihrem Standort herbeirufen? - Mich in [REGION] beitreten lassen + Triff mich in [REGION] - + - Geben Sie eine kurze Ankündigung ein, die -an alle derzeit auf Ihrer Länderei befindlichen Personen gesendet wird. + Geben Sie eine kurze Nachricht ein, die +an jede Person auf Ihrem Grundstück gesendet wird. - + - Sie sind dabei, eine Länderei in Linden-Besitz zu ändern (Festland, -Teen-Raster, Ausrichtung usw.). + Sie sind im Begriff, ein Grundstück in Linden-Besitz (Mainland, +Teen-Raster, Orientierung usw.) zu verändern. -Das ist ÄUSSERST GEFÄHRLICH, weil sich dies grundlegend -auf die Benutzererfahrung auswirken kann. Auf dem Festland ändert dies -Tausende von Regionen und führt zu Spaceserver-Problemen. +Dies ist ÄUSSERST GEFÄHRLICH, da es grundlegene Auswirkungen +auf das Benutzererlebnis hat. Auf dem Mainland werden tausende +Regionen geändert, was den Spaceserver stark belastet. Fortfahren? - + - Sie sind dabei, die Zugangsliste für eine Länderei in Linden-Besitz -zu ändern (Festland, Teen-Raster, Ausrichtung usw.). + Sie sind im Begriff, die Zugangsliste für ein Grundstück in Linden-Besitz +(Mainland, Teen-Raster, Orientierung usw.) zu verändern. -Dies ist GEFÄHRLICH und sollte nur gemacht werden, um den -Hack aufzurufen, der gestattet, dass Objekte/Geld in/aus einem Raster -transferiert werden. +Dies ist GEFÄHRLICH und sollte nur erfolgen, um Objekte/L$ +per Hack in und aus dem Raster zu +entfernen. -Dies ändert Tausende von Regionen und führt zu -Spaceserver-Problemen. - -Fortfahren? +Tausende Regionen werden verändert und der +Spaceserver wird dadurch stark belastet. - + - Zur Genehmigungsliste nur für diese Länderei oder für [ALL_ESTATES] hinzufügen? + Nur für dieses Grundstück oder für alle [ALL_ESTATES] zur Erlaubnisliste hinzufügen? - + - Nur für diese Länderei oder für [ALL_ESTATES] von der Genehmigungsliste entfernen? + Nur für dieses Grundstück oder für alle [ALL_ESTATES] von Erlaubnisliste entfernen? - + - Zur Gruppengenehmigungsliste nur für diese Länderei oder für [ALL_ESTATES] hinzufügen? + Nur für dieses Grundstück oder für alle [ALL_ESTATES] zur Gruppen-Erlaubnisliste hinzufügen? - + - Nur für diese Länderei oder für [ALL_ESTATES] aus der Gruppe entfernen? + Nur für dieses Grundstück oder für alle [ALL_ESTATES] von Gruppen-Erlaubnisliste entfernen? - + - Zugang nur für diese Länderei oder für [ALL_ESTATES] verweigern? + Zugang nur für dieses Grundstück oder für [ALL_ESTATES] verweigern? - + - Zugangsverweigerung nur für diese Länderei oder für [ALL_ESTATES] aufheben? + Einwohner nur für dieses Grundstück oder für alle [ALL_ESTATES] von der Bannliste entfernen? - + - Ländereimanager nur für diese oder für alle Ihre Ländereien hinzufügen? + Verwalter nur für dieses Grundstück oder für [ALL_ESTATES] festlegen? - + - Ländereimanager nur für diese oder für alle Ihre Ländereien entfernen? + Verwalter nur für dieses Grundstück oder für [ALL_ESTATES] entfernen? - + - Vertragsmeldung nur für diese Länderei oder für [ALL_ESTATES] ändern? + Vertragsmeldung nur für dieses Grundstück oder für [ALL_ESTATES] festlegen? - + - [EVIL_USER] von dieser Länderei verjagen? + Benutzer [EVIL_USER] von diesem Grundstück werfen? - Möchten Sie den Ländereienvertrag wirklich löschen? + Möchten Sie den Grundstücksvertrag wirklich ändern? - Problem beim Import des Ländereienvertrags. + Problem beim Import des Grundstückvertrags. - Asset der Grußkarte kann derzeit nicht geladen werden. + Notizkarten-Asset konnte nicht geladen werden. - Berechtigungen reichen nicht aus, um eine der angeforderten Asset-ID zugeordnete Grußkarte anzuzeigen. + Unzureichende Rechte, um die mit der angeforderten Asset-ID verbundene Notizkarte anzuzeigen. - Asset-ID für Grußkarte fehlt in Datenbank. + Asset-ID für Notizkarte fehlt in Datenbank. - Nicht vergessen: Anzeigengebühren können nicht rückerstattet werden. + Hinweis: Anzeigengebühren werden nicht zurückerstattet. -Diese Anzeige jetzt für L$ [AMOUNT] veröffentlichen? +Anzeige für [AMOUNT] L$ veröffentlichen? - Möchten Sie diese Region wirklich in 2 Minuten neu starten? + Möchten Sie diese Region in 2 Minuten neu starten? - + - Geben Sie eine kurze Ankündigung ein, die -an alle derzeit in dieser Region befindlichen Personen gesendet wird. + Geben Sie eine kurze Nachricht ein, die +an jede Person in dieser Region gesendet wird. - Ist dieses Kästchen aktiviert, können Landeigentümer ihr Land nicht -terraformen, egal wie 'Terrain bearbeiten' für die einzelne Parzelle eingestellt ist. + Wenn diese Option aktiviert ist, können Landeigentümer Ihr Land nicht +terraformen. Ausgenommen davon ist die parzelleneigene Einstellung ' Terrain bearbeiten'. Standard: aus - Ist dieses Kästchen aktiviert, können Personen in dieser Region nicht fliegen, -egal wie 'Fliegen' für die einzelne Parzelle eingestellt ist. + Wenn diese Option aktiviert ist, ist Fliegen in dieser Region nicht möglich, +auch wenn für die Parzelle eine andere Einstellung aktiv ist. Standard: aus - Durch Aktivieren dieses Kästchen wird das Gesundheitssystem über alle Parzellen hinweg -unabhängig von den einzelnen Parzelleneinstellungen aktiviert. Bleibt dieses Kästchen -deaktiviert, können einzelne Parzelleneigentümer weiterhin -das Gesundheitssystem auf ihren Parzellen aktivieren. + Wenn diese Option aktiviert ist, ist das Gesundheitssystem auf +allen Parzellen aktiviert, unabhängig von den Parzelleneinstellungen. Ist die Option links +deaktiviert, können die Parzelleneigentümer das Gesundheitssystem +individuell einschalten. Standard: aus - + - Legt die maximale Anzahl in dieser Region zulässiger Avatare fest. -Je mehr Avatare Sie in einer Region haben, desto schlechter kann -die Leistung sein. + Legt die maximale Anzahl an Avataren für diese Region fest. +Die Leistung hängt von der Anzahl der +Avatare in der Region ab. -Standard: 30 +Standard: 40 - Der Objektbonus ist ein Multiplikator für alle für eine bestimmte Parzelle -zulässigen Primitiva. Der zulässige Bereich ist 1 bis 10. Bei Einstellung auf '1' wären für jede 512 m2-Parzelle -117 Objekte zulässig. Bei Einstellung auf '2' wären für jede 512 m2-Parzelle -234 oder doppelt so viele zulässig, usw. Die max. Anzahl der Objekte -pro Region bleibt bei 15.000, egal welcher Wert für den Objektbonus -eingestellt wird. Wird dieser Wert eingestellt, sollte er erst reduziert werden, wenn -Sie sicher sind, dass die Änderung nicht die Rückkehr oder das Löschen der -derzeit auf Parzellen befindlichen Objekte erzwingt. + Der Objektbonus ist ein Multiplikator für die Anzahl an zulässigen Primitiven +auf einer Parzelle. Gültig sind Werte zwischen 1 und 10. '1' erlaubt auf einer 512 qm +großen Parzelle 117 Objekte. '2' erlaubt auf einer 512 qm großen Parzelle +234 Objekte, also die doppelte Menge. Die maximale Objektanzahl +in einer Region beträgt unabhängig vom Objektbonus 15.000. +Eine nachträglich Senkung des Objektbonus führt dazu, dass Objekte zurückgegeben +oder gelöscht werden. Standard: 1.0 - + - Legt die Maturity der Region fest, wie oben rechts auf dem Bildschirm und -in den Popup-Tipps auf der Karte angegeben. Maturity -wirkt sich auch auf Suchergebnisse aus, Einwohner können sich entschließen, -Inhalt in Mature-Regionen nicht zu finden. + Legt die Alterseinstufung für diese Region fest, wie oben + im Bildschirm und in den Popup-Tipps auf der Karte gezeigt. Diese Einstellung +hat auch Auswirkungen auf die Suchergebnisse – Einwohner können +entscheiden, dass Ab-18-Regionen nicht angezeigt werden. -Die Popup-Tipps auf der Karte ändern sich 5 Minuten lang nicht, weil -das System Karteninformationen nur in regelmäßigen Abständen aktualisiert. +Es kann eine Weile dauern, bis sich diese Änderung auf +die Karte auswirkt. -Standard: PG +Standard: Jugendfrei - + - Stellt die ganze Region auf beschränkte Push-Berechtigungen ein. -Makler können nur sich selbst pushen oder von Skripts gepusht werden, die -dem Eigentümer einer Parzelle gehören oder auf die Gruppe der Parzelle eingestellt sind, -falls die Parzelle eine Gruppe eingestellt/zugewiesen hat. -Push bezieht sich auf die llPushObject() LSL-Funktion. + Aktivieren sie diese Option, um in der gesamten Region das Stoßen zu +beschränken. Wenn aktiviert, können Einwohner nur von sich selbst +oder vom Parzelleneigentümer gestoßen werden. +(Stoßen meint die LSL-Funktion llPushObject().) Standard: aus - + - Legt fest, ob Parzellen, die nicht dem Ländereieigentümer gehören, -zusammengefügt oder unterteilt werden können. -Ist diese Option deaktiviert, gilt folgendes: - * Nur Ländereieigentümer oder -manager können Parzellen zusammenfügen oder unterteilen. - {} * Sie können nur Parzellen zusammenfügen oder unterteilen, die dem - Eigentümer oder einer Gruppe gehören, in der sie die jeweiligen Gruppenberechtigungen besitzen. -Ist diese Option aktiviert, gilt folgendes: - * Alle Parzelleneigentümer können die Parzellen in ihrem Eigentum zusammenfügen oder unterteilen. - * Für Parzellen in Gruppeneigentum können Benutzer mit den jeweiligen - Gruppenberechtigungen Parzellen zusammenfügen oder unterteilen. - -Standard: aktiviert + Dieses Kontrollkästchen steuert, ob Parzellen des Grundstückseigentümers +zusammengelegt bzw. unterteilt werden können. Wenn deaktiviert: + * Nur Grundstückseigentümer bzw. –verwalter können Parzellen zusammenlegen/teilen. * Sie können nur Parzellen zusammenlegen/teilen, die dem Eigentümer oder einer Gruppe gehören, bei der sie entsprechende Gruppenrechte innehaben. +Wenn aktiviert: + * Die Parzelleneigentümer können ihre Parzellen selbst zusammenlegen/teilen. * Parzellen in Gruppeneigentum können von Mitgliedern mit den + entsprechenden Rechten zusammengelegt bzw. unterteilt werden. + Standard: aktiviert - + - Die Maturity-Einstufung für diese Region wurde aktualisiert. + Die Alterseinstufung dieser Region wurde aktualisiert. -Die Weltkarte benötigt für die Aktualisierung aber ca. 5 Minuten, -weil das System Karteninformationen nur in regelmäßigen Abständen -aktualisiert. +Es kann eine Weile dauern, bis sich die Änderung auf +die Karte auswirkt. - Ländereieigentümer und -manager können nur Land verkaufen, das dem Ländereieigentümer gehört. -Bleibt diese Option deaktiviert, können Käufer ihr Land in dieser Region nicht wieder verkaufen. -Ist diese Option aktiviert, können Käufer ihr Land in dieser Region wieder verkaufen. + Grundstückseigentümer und -verwalter können jedes Land im Besitz des Grundstückseigentümers verkaufen. +Ist diese Option deaktiviert, können Käufer ihr Land in dieser Region nicht weiterverkaufen. +Ist die Option aktiviert, können Käufer ihr Land in dieser Region weiterverkaufen. -Standard: Nicht zulassen +Standard: deaktiviert - + - Legt die Grußkarten-Asset-ID für den Ländereienvertrag fest, zu dem diese Länderei -gehört. + Legt die Notizkarten-Asset-ID für den Grundstücksvertrag dieses Grundstücks +fest. -Standard: 00000000-0000-0000-0000-000000000000 oder keine Eingabe +Standard: 00000000-0000-0000-0000-000000000000 oder leer - Ist die Sim-Leistung mangelhaft, ist evtl. ein Skript schuld. Öffnen Sie die -Statistikleiste (Strg-Umschalttaste-1). Zeigen Sie die Simulator-Physik-FPS an. -Steht diese unter 45, öffnen Sie das Feld 'Zeit' unten in der -Statistikleiste. Lautet die Skriptzeit 25 ms oder mehr, klicken Sie auf -die Schaltfläche 'Wichtigste Skripts abrufen'. Sie erhalten Namen und Position -der Skripts, die möglicherweise die mangelhafte Leistung verursachen. - -Markieren Sie das Kästchen 'Skripts deaktivieren' und klicken Sie auf 'Ãœbernehmen', um -alle Skripts in dieser Region vorübergehend zu deaktivieren. Sie müssen -diesen Schritt evtl. ergreifen, um an die Position eines angegebenen -'wichtigen Skripts' zu gelangen. Wenn Sie dort angekommen sind, untersuchen Sie das Skript, -um zu bestimmen, ob es das Problem verursacht. Sie müssen evtl. -den Eigentümer des Skripts kontaktieren oder das Objekt löschen oder zurückgeben. -Heben Sie die Markierung des Kästchens 'Skripts deaktivieren' auf und klicken Sie auf 'Ãœbernehmen', um -die Skripts in der Region wieder zu aktivieren. - -Standard: aus + Schlechte Sim-Performance ist oftmals auf ein Skript zurückzuführen. Öffnen Sie +die Statistikleiste (Strg-Umschalt-1). Sehen Sie sich den Wert für 'Simulator Physics FPS' (Simulator Physik-FPS) an. +Wenn der Wert unter 45 liegt, öffnen Sie den Bereich 'Time' (Zeit) ganz unten in der Statistikleiste. Wenn der Wert für "Script Time" (Skriptzeit) 25 ms oder höher ist, klicken Sie auf 'Top-Skripts'. Der Name und die Position der Skripts, die für die schlechte Performance verantwortlich sind, werden angezeigt. + Wenn Sie das Kontrollkästchen 'Skripts deaktivieren' aktivieren und auf 'Ãœbernehmen' klicken, werden alle Skripts in der Region zeitweilig deaktiviert. Dieser Schritt ist eventuell notwendig, damit Sie an die Position des gemeldeten 'Top-Skripts' reisen können. Sobald Sie dort angekommen sind, sollten Sie das Skript auf die Ursache des Problems hin untersuchen. Möglicherweise müssen Sie sich an den Skript-Eigentümer wenden oder das Objekt löschen bzw. zurückgeben. Um die Skripte in der Region wieder zu aktivieren, deaktivieren Sie 'Skript deaktivieren' und klicken Sie auf 'Ãœbernehmen'. + Standard: aus - Ist die Sim-Leistung mangelhaft, sind evtl. physische Objekte schuld. -Öffnen Sie die Statistikleiste (Strg-Umschalttaste-1). Zeigen Sie die Simulator- -Physik-FPS an. Steht diese unter 45, öffnen Sie das Feld 'Zeit' unten in der -Statistikleiste. Lautet die Sim-Zeit (Physik) -20 ms oder mehr, klicken Sie auf 'Wichtigste Kollisionsobjekte abrufen'. -Sie erhalten Namen und Position physischer Objekte, -die möglicherweise die mangelhafte Leistung verursachen. - -Markieren Sie das Kästchen 'Kollisionen deaktivieren' und klicken Sie auf 'Ãœbernehmen', um -Objekt-Objekt-Kollisionen vorübergehend zu deaktivieren. Sie müssen -diesen Schritt evtl. ergreifen, um an die Position eines angegebenen -'wichtigen Kollisionsobjekts' zu gelangen. Wenn Sie dort angekommen sind, untersuchen Sie das Objekt, -- kollidiert es ständig mit anderen Objekten? Sie müssen evtl. -den Eigentümer des Objekts kontaktieren oder das Objekt löschen oder zurückgeben. -Heben Sie die Markierung des Kästchens 'Kollisionen deaktivieren' auf und klicken Sie auf 'Ãœbernehmen', um -Kollisionen in der Region wieder zu aktivieren. - -Standard: aus + Schlechte Sim-Performance ist oftmals auf physische Objekte zurückzuführen. Öffnen Sie die Statistikleiste (Strg-Umschalt-1). Sehen Sie sich den Wert für 'Simulator Physics FPS' (Simulator Physik-FPS) an. Wenn der Wert unter 45 liegt, öffnen Sie den Bereich 'Time' (Zeit) ganz unten in der Statistikleiste. Wenn der Wert für 'Sim Time (Physics) ' [Sim Time (Physik)] 20 ms oder höher ist, klicken Sie auf 'Top-Kollisionsobjekte'. Der Name und die Position der physikalischen Objekte, die für die schlechte Performance verantwortlich sind, werden angezeigt. + Wenn Sie das Kontrollkästchen 'Kollisionen deaktivieren' aktivieren und auf +'Ãœbernehmen' klicken, werden alle Objekt-Objekt-Kollisionen in der Region zeitweilig deaktiviert. Dieser Schritt ist eventuell notwendig, damit Sie an die Position des gemeldeten 'Top-Kollisionsobjekts' reisen können. Sobald Sie dort angekommen sind, sollten Sie das Objekt untersuchen – kollidiert es ständig mit anderen Objekten? Möglicherweise müssen Sie sich an den Objekt-Eigentümer wenden oder das Objekt löschen bzw. zurückgeben. Um Kollisionen in der Region wieder zu aktivieren, deaktivieren Sie 'Kollisionen deaktivieren' und klicken Sie auf 'Ãœbernehmen'. + Standard: aus - Das Deaktivieren der Physik ähnelt dem Deaktivieren von Kollisionen, außer dass die gesamte -Physiksimulation deaktiviert wird. Das bedeutet nicht nur, dass -Objekte nicht mehr kollidieren, sondern dass Avatare sich nicht bewegen können. + Das Deaktivieren der Physik ähnelt dem Deaktivieren von Kollisionen, +außer dass die gesamte Physiksimulation ausgeschaltet wird. Das hat nicht nur zur Folge, dass +Objekte nicht mehr kollidieren, sondern dass Avatare sich nicht mehr bewegen können. -Dies sollte nur verwendet werden, wenn 'Kollisionen deaktivieren' nicht -genug Leistung für die Region bietet, um ein Physikproblem -oder 'Wichtigstes Kollisionsobjekt' zu untersuchen. +Diese Option sollte nur verwendet werden, wenn das Deaktivieren +von Kollisionen keine ausreichende Leistungssteigerung bringt, +um Physikprobleme in der Region oder die Top-Kollisionsobjekte zu erkennen. -Vergessen Sie nicht, die Physik danach wieder zu aktivieren, ansonsten -können sich Avatare weiterhin nicht bewegen. +Schalten Sie die Physiksimulation hinterher wieder ein. Andernfalls +können sich Avatare nicht mehr bewegen. Standard: aus - + - Eine Liste der Objekte anzeigen, die die größte Anzahl -potenzieller Objekt-Objekt-Kollisionen aufweisen. Diese Objekte können die Sim-Leistung verlangsamen. Wählen Sie 'Ansicht' > 'Statistikleiste' und -suchen Sie unter 'Simulator' > 'Zeit' > 'Sim-Zeit (Physik)', um zu sehen, -ob mehr als 20 ms in Physik verbracht werden. + Zeigt eine Liste der Objekte mit den potenziell meisten +Objekt-Objekt-Kollisionen an. Diese Objekte können +die Leistung beeinträchtigen. Wählen Sie 'Ansicht' > 'Statistikleiste' aus und +sehen Sie unter 'Simulator' > 'Time' > 'Sim Time (Physics)' nach, +ob die Physikberechnung länger als 20 ms dauert. - + - Eine Liste der Objekte anzeigen, die die meiste Zeit mit der Ausführung von -verbringen. Diese Objekte können die Sim-Leistung verlangsamen. + Zeigt eine Liste der Objekte an, die die meiste Zeit benötigen um +LSL-Skripts auszuführen. Diese Objekte können die Leistung beeinträchtigen. Wählen Sie 'Ansicht' > 'Statistikleiste' und -suchen Sie unter 'Simulator' > 'Zeit' > 'Skript-Zeit', um zu sehen, ob mehr als -25 ms in Skripts verbracht werden. +sehen Sie unter 'Simulator' > 'Time' > 'Script Time' nach, +ob mehr als 25 ms für Skripts benötigt werden. - Starten Sie den Servervorgang, der diese Region ausführt, nach einer 2 Minuten-Warnung erneut. Alle Einwohner in der Region werden -abgetrennt. Die Region speichert ihre Daten und sollte -innerhalb von 90 Sekunden wieder laufen. + Starten Sie den Serverprozess für diese Region nach der +2-Minuten-Warnung neu. Die Verbindung aller Einwohner in dieser Region wird +getrennt. Die Region wird gespeichert und sollte nach +90 Sekunden wieder verfügbar sein. -Durch Neustart der Region werden die meisten Leistungsprobleme -nicht behoben. Ein Neustart sollte nur durchgeführt werden, wenn Sie dazu angewiesen werden. +Der Neustart der Region behebt die meisten Leistungs- +probleme, sollte aber nur nach Anweisung erfolgen. - Dies ist die Höhe in Metern, bei der man auf Wasser stößt. Ist -diese Einstellung ein anderer Wert als 20 und haben Sie -Wasser neben der Weltkante oder 'Abgrundwasser', -so gibt es eine sichtbare Lücke. + Die Höhe der Wasserlinie in Metern. Liegt +dieser Wert unter 20 und haben Sie Wasser nahe am Rand der +Welt oder 'offenes' Wasser definiert, wird eine +deutliche Lücke sichtbar. Standard: 20 - + - Dies ist die Distanz, um die der Parzelleneigentümer sein -Terrain über die 'geformte' Terrainstandardhöhe -anheben kann. + Der maximale Betrag in Metern, um den Parzelleneigentümer +ihr Terrain über die Standardhöhe des 'geformten' Terrains +erhöhen können. Standard: 4 - + - Dies ist die Distanz, um die der Parzelleneigentümer sein -Terrain unter die 'geformte' Terrainstandardhöhe -absenken kann. + Der maximale Betrag in Metern, um den Parzelleneigentümer +ihr Terrain unter die Standardhöhe des 'geformten' Terrains +absenken können. Standard: -4 - Diese Schaltfläche lädt eine .RAW-Datei in die Region, in der Sie sich befinden. -Die Datei muss die korrekten Maße/Kanalanzahl haben: -RGB, 256x256 und 13 Kanäle. Eine Terrain-Datei lässt sich -am besten durch Herunterladen der vorhandenen RAW-Datei erstellen. Ändern Sie -zunächst den ersten Kanal (Landhöhe) und -laden Sie diese Einstellung hoch. - -Der Upload kann bis zu 45 Sekunden dauern. Durch Hochladen einer -Terrain-Datei werden Objekte auf dem Land *nicht* verschoben, -sondern nur das Terrain selbst und die mit den Parzellen verbundenen -Zulassungen. Dies kann dazu führen, dass Objekte unterirdisch werden. - -Weitere Informationen zur Bearbeitung von Regionshöhenfeldern: -http://secondlife.com/tiki/tiki-index.php?page=RawTerrainFile + Mit dieser Schaltfläche laden Sie eine RAW-Datei in die Region hoch, in der Sie sich befinden. Die Datei muss die korrekten Maße (RGB, 256x256) und 13 Kanäle haben. Um eine neue Terraindatei zu erstellen, laden Sie am besten die vorhandene RAW-Datei herunter. Beginnen Sie damit, den Rot-Kanal (Höhe des Landes) zu bearbeiten und laden Sie die Datei wieder hoch. Der Ladevorgang kann bis zu 45 Sekunden dauern. Beachten Sie, dass beim Hochladen einer Terraindatei die Objekte auf dem Land *nicht* verschoben werden, sondern nur das Land und die mit den Parzellen verbundenen Berechtigungen. Dies kann dazu führen, dass Objekte unter dem Terrain verschwinden. Weitere Informationen zur Bearbeitung der Höhendaten der Region enthält die F1-Hilfe. - Diese Schaltfläche lädt eine Datei mit Höhenfelddaten, -Parzellenabmessungen, Parzelle zum Verkauf-Status und einigen Parzellenberechtigungen -für diese Region herunter. Wenn Sie die Datei in einem Programm wie -Photoshop öffnen, müssen Sie die Abmessungen des Dokuments angeben, die wie folgt -lauten: RGB, 256x256 mit 13 Kanälen. Diese Terraindatei kann nicht -auf andere Weise geöffnet werden. + Mit dieser Schaltfläche laden Sie eine Datei herunter, welche +die Höhendaten, Maße, den Verkaufsstatus der Parzelle und einige +Parzellenrechte für diese Region enthält. Wenn Sie diese Datei in einem Programm wie +Photoshop öffnen, müssen Sie die Bilddaten eingeben. Diese +sind: RGB, 256x256 mit 13 Kanälen. Anders lässt sich diese +Terraindatei nicht öffnen. -Weitere Informationen zur Bearbeitung von Regionshöhenfeldern: -http://secondlife.com/tiki/tiki-index.php?page=RawTerrainFile +Weitere Informationen zur Bearbeitung der Höhendaten der Region enthält die F1-Hilfe. - + - Dieses Kontrollkästchen bewirkt, dass die Sonnenposition in dieser Region -mit der im Rest der Länderei identisch ist. + Aktivieren Sie diese Option, um in dieser Region denselben +Sonnenstand wie auf dem restlichen Grundstück einzustellen. Standard: ein - Dieses Kontrollkästchen legt die Sonnenposition auf die Position -im Phasen-Schieberegler fest und stoppt die Sonnenbewegung. + Aktivieren Sie diese Option, um den Sonnenstand auf +die im Regler definierte Position festzulegen und die Animation auszuschalten. Standard: aus - Diese Schaltfläche speichert die aktuelle Form des Terrains als -neuen Standard für die Region. Nach der Formung kann das Land -auf die gespeicherte Form zurückgeführt werden, wenn Sie oder andere Landbearbeitungs-Tool/die Option -'Zurückführen' verwenden. Das geformte Terrain ist auch der Mittelpunkt -für die Terrain-anheben- und -senken-Grenzen. + Mit dieser Schaltfläche speichern Sie die aktuelle Terrain-Form +als neuen Standard für die Region. Nach der Formung können Sie und andere +das Land mit der Option 'Terrain bearbeiten' > 'Zurücksetzen' +in den ursprünglichen Zustand zurückversetzen. Das geformte Terrain ist auch das Zentrum +für die oberen und unteren Terraingrenzen. - + - Ein Ländereimanager ist ein Einwohner, dem Sie die Kontrolle -über Regions- und Ländereieinstellungen übertragen haben. Ein Ländereimanager -kann alle Einstellungen dieser Felder ändern, außer Hochladen, -Herunterladen und Terrainformung. Vor allem kann er -Einwohner auf Ihre Länderei lassen oder diese verbannen. + Ein Grundstücksverwalter ist ein Einwohner, dem Sie die Kontrolle +über die Regions- und Grundstückseinstellungen übertragen haben. Ein Grundstücksverwalter +kann alle Einstellungen ändern, außer das Hochladen, +Herunterladen und Formen von Terrain. Vor allem kann er Einwohner +auf dem Grundstück erlauben und davon verbannen. -Ländereimanager können nur vom Eigentümer der Länderei -hinzugefügt oder entfernt werden, nicht von einem anderen Ländereimanager. Bitte wählen Sie nur -Einwohner als Ländereimanager, denen Sie vertrauen, da letztendlich -Sie für deren Aktionen verantwortlich sind. +Nur der Eigentümer kann den Grundstücksverwalter +bestimmen und entlassen. Der Verwalter hat dieses Recht nicht. Wählen Sie nur vertrauenswürdige +Einwohner als Grundstücksverwalter, da Sie letztlich für +deren Handlungen verantwortlich sind. - Dieses Kontrollkästchen bewirkt, dass die Sonne in Ihrer Länderei -die gleiche Position wie auf den 'Festland'- -Ländereien in Linden-Besitz verfolgt. + Aktivieren Sie diese Option, um auf Ihrem Grundstück +denselben Sonnenstand wie auf dem Linden-'Mainland' +einzustellen. Standard: ein - Dieses Kontrollkästchen legt die Sonnenposition auf die Position -im Phasen-Schieberegler fest und stoppt die Sonnenbewegung. + Aktivieren Sie diese Option, um den Sonnenstand auf +die im Regler definierte Position festzulegen und die Animation auszuschalten. - + - Sets whether residents who are on other estates can enter this - estate without being on an access list. + Aktivieren Sie diese Option, um Einwohnern den Zugang zu diesem Grundstück zu + erlauben, ohne auf der Zugangsliste zu stehen. -Default: on +Standard: ein - Bei Aktivierung ermöglicht dies Einwohnern, sich per Teleport an jeden -beliebigen Punkt in ihrer Länderei zu begeben. Wenn nicht aktiviert, werden Einwohner per Teleport -zum nächstgelegenen Telehub transportiert. + Wenn aktiviert, können sich Einwohner an jede Stelle auf +Ihrem Grundstück teleportieren. Wenn deaktiviert, werden Einwohner +zum nächstgelegenen Telehub teleportiert. Standard: aus - + - Falls ein Bewohner hier aufgeführt wird, ist der Zugang zur Länderei -auf die Bewohner dieser Liste und die unten aufgeführten Gruppen beschränkt. - -(Wenn die Länderei vom Festland aus sichtbar ist, kann der Zugang nicht auf -eine Einwohner- oder Gruppenliste beschränkt werden und diese Steuerelemente sind -deaktiviert. Nur die 'Zugang verweigert'-Liste wird verwendet.) + Der Zugang zu diesem Grundstück wird auf die hier + aufgeführten Einwohner und Gruppen beschränkt. Diese Einstellung ist + nur verfügbar, wenn 'Vom Festland aus sichtbar' + deaktiviert ist. - + - Falls eine Gruppe hier aufgeführt wird, ist der Zugang zur Länderei -auf die Gruppen in dieser Liste und die speziell oben zugelassenen -Einwohner beschränkt. - -(Wenn die Länderei vom Festland aus sichtbar ist, kann der Zugang nicht auf -eine Einwohner- oder Gruppenliste beschränkt werden und diese Steuerelemente sind -deaktiviert. Nur die 'Zugang verweigert'-Liste wird verwendet.) + Der Zugang zu diesem Grundstück wird auf die hier + aufgeführten Einwohner und Gruppen beschränkt. Diese Einstellung ist + nur verfügbar, wenn 'Vom Festland aus sichtbar' + deaktiviert ist. - Einwohnern auf dieser Liste wird der Zugang zu Ihrer Länderei verweigert, -und zwar unabhängig von den Genehmigungs- und Gruppeneinstellungen oben. - -Wenn ein Einwohner zu dieser Liste hinzugefügt wird, wird er aus der -Genehmigungsliste entfernt. + Einwohnern auf dieser Liste wird der Zugang zum Grundstück verwehrt, +unabhängig von etwaigen anderen Einstellungen. - + - Durch Festlegen eines Ländereienvertrags können Sie Parzellen -innerhalb dieser Länderei verkaufen. Ist kein Vertrag eingestellt, können Sie das -Land nicht verkaufen. Die Grußkarte für Ihren Vertrag kann leer sein, -falls Sie keine Regeln anwenden möchten oder Käufer nicht -über das Land informieren möchten, bevor sie es kaufen. - -Ein Vertrag kann dazu verwendet werden, Regeln, Richtlinien, -kulturelle Informationen oder einfach Ihre eigenen Erwartungen einem -potenziellen Käufer zu vermitteln. Dies kann Bebauungsplan-, Bauvorschriften, -Bezahlungsoptionen oder andere Informationen umfassen, die Ihrer Meinung -nach der neue Eigentümer einsehen oder denen er zustimmen sollte, -bevor er das Objekt kauft. - -Der Käufer muss dem Vertrag zustimmen, indem er das Kontrollkästchen -aktiviert, bevor er den Kauf abschließen kann. Ländereienverträge sind stets im Dialogfeld 'Info zu Land' ersichtlich, -so lange sie für Parzellen festgelegt sind. + Ein Grundstücksvertrag ermöglicht es Ihnen, Grundstücksparzellen zu verkaufen. Ohne Vertrag können Sie kein Land verkaufen. Wenn Sie keine Regeln festlegen oder Käufern vor dem Kauf keine anderen Informationen über das Land bereitstellen möchten, können Sie die Vertrags-Notizkarte auch leer lassen. Ein Vertrag kann Regeln und Richtlinien, kulturelle Informationen oder einfach nur Ihre eigenen Erwartungen bezüglich der Landnutzung durch den Käufer enthalten. Das kann Zoning, Baubeschränkungen, Zahloptionen und alle möglichen anderen Informationen betreffen, die der neue Eigentümer Ihrer Meinung nach kennen und akzeptieren sollte. Der Käufer muss dem Vertrag durch Auswahl dieses Kontrollkästchens zustimmen, bevor der Kauf abgeschlossen werden kann. Grundstücksverträge sind jederzeit unter 'Land-Info' für jede Parzelle einsehbar, für die ein Vertrag definiert wurde. - + - Es kann nicht mehr als ein Objekt gleichzeitig gekauft werden. -Bitte wählen Sie nur ein Objekt und versuchen Sie es noch einmal. + Sie können jeweils nur ein Objekt kaufen. +Wählen Sie ein einzelnes Objekt aus und versuchen Sie es erneut. - + - Objekte können nicht gleichzeitig von verschiedenen Eigentümern gekauft werden. -Bitte wählen Sie nur ein Objekt und versuchen Sie es noch einmal. + Objekte können nicht von mehreren Eigentümern gleichzeitig gekauft werden. +Wählen Sie ein einzelnes Objekt aus und versuchen Sie es erneut. - + - Es kann nicht der Inhalt von mehr als einem Objekt gleichzeitig gekauft werden. -Bitte wählen Sie nur ein Objekt und versuchen Sie es noch einmal. + Inhalte können jeweils nur für ein Objekt gekauft werden. +Wählen Sie ein einzelnes Objekt aus und versuchen Sie es erneut. - + - Objekte können nicht gleichzeitig von verschiedenen Eigentümern gekauft werden. -Bitte wählen Sie nur ein Objekt und versuchen Sie es noch einmal. + Objekte können nicht von mehreren Eigentümern gleichzeitig gekauft werden. +Wählen Sie ein einzelnes Objekt aus und versuchen Sie es erneut. @@ -3804,15 +3872,15 @@ Bitte wählen Sie nur ein Objekt und versuchen Sie es noch einmal. - Originalobjekt von [OWNER] für L$ [PRICE] kaufen? -Sie werden Eigentümer dieses Objekts. -Sie werden zu folgendem in der Lage sein: - Ändern: [MODIFYPERM] + Von [OWNER] Originalobjekt für [PRICE] L$ kaufen? +Sie werden der Eigentümer dieses Objekts. +Sie können das Objekt: + Bearbeiten: [MODIFYPERM] Kopieren: [COPYPERM] - Wiederverkaufen oder Hergeben: [RESELLPERM] + Verkaufen oder weggeben: [RESELLPERM] - Originalobjekt für L$ [PRICE] kaufen? -Sie werden Eigentümer dieses Objekts. -Sie werden zu folgendem in der Lage sein: - Ändern: [MODIFYPERM] + Originalobjekt für [PRICE] L$ kaufen? +Sie werden der Eigentümer dieses Objekts. +Sie können das Objekt: + Bearbeiten: [MODIFYPERM] Kopieren: [COPYPERM] - Wiederverkaufen oder Hergeben: [RESELLPERM] + Verkaufen oder weggeben: [RESELLPERM] - Eine Kopie von [OWNER] für L$ [PRICE] kaufen? + Von [OWNER] Kopie für [PRICE] L$ kaufen? Das Objekt wird in Ihr Inventar kopiert. -Sie werden zu folgendem in der Lage sein: - Ändern: [MODIFYPERM] +Sie können das Objekt: + Bearbeiten: [MODIFYPERM] Kopieren: [COPYPERM] - Wiederverkaufen oder Hergeben: [RESELLPERM] + Verkaufen oder weggeben: [RESELLPERM] - Eine Kopie für L$ [PRICE] kaufen? + Kopie für [PRICE] L$ kaufen? Das Objekt wird in Ihr Inventar kopiert. -Sie werden zu folgendem in der Lage sein: - Ändern: [MODIFYPERM] +Sie können das Objekt: + Bearbeiten: [MODIFYPERM] Kopieren: [COPYPERM] - Wiederverkaufen oder Hergeben: [RESELLPERM] + Verkaufen oder weggeben: [RESELLPERM] - Inhalt von [OWNER] für L$ [PRICE] kaufen? -Wird in Ihr Inventar kopiert. + Von [OWNER] Inhalte für [PRICE] L$ kaufen? +Die Inhalte werden in Ihr Inventar kopiert. - Inhalt für L$ [PRICE] kaufen? -Wird in Ihr Inventar kopiert. + Inhalte für [PRICE] L$ kaufen? +Die Inhalte werden in Ihr Inventar kopiert. - Diese Transaktion wird: + Transaktion: [ACTION] -Möchten Sie mit diesem Kauf wirklich fortfahren? +Möchten Sie diesen Kauf fortsetzen? - Diese Transaktion wird: + Transaktion: [ACTION] -Möchten Sie mit diesem Kauf wirklich fortfahren? -Bitte geben Sie Ihr Kennwort erneut ein und klicken Sie auf 'Bestätigen'. +Möchten Sie diesen Kauf fortsetzen? +Geben Sie Ihr Kennwort erneut ein und klicken Sie auf OK. - Sie haben nicht kopierfähige Inventarobjekte ausgewählt. -Diese Objekte werden in Ihr Inventar verschoben, nicht kopiert. + Sie haben 'nicht kopierfähige' Inventarobjekte ausgewählt. +Diese Objekte werden nicht kopiert, sondern in Ihr Inventar verschoben. Inventarobjekt(e) verschieben? + + Beim Verschieben von nicht-kopierfähigem Inventar von Objekten + - Sie haben nicht kopierfähige Inventarobjekte ausgewählt. Diese Objekte werden in Ihr Inventar verschoben, nicht kopiert. + Sie haben 'nicht kopierfähige' Inventarobjekte ausgewählt. Diese Objekte +werden nicht kopiert, sondern in Ihr Inventar verschoben. -Weil dieses Objekt ein Scripting-Objekt ist, verursacht das Verschieben dieser Objekte -in Ihr Inventar evtl. eine Skriptfehlfunktion. +Da es sich um ein geskriptetes Objekt handelt, geht +die Skriptfunktion beim Verschieben in das Inventar möglicherweise verloren. Inventarobjekt(e) verschieben? + + Beim Verschieben von nicht-kopierfähigem Inventar von geskripteten Objekten + - Warnung: Die 'Objekt zahlen'-Klickhandlung wurde festgelegt, doch -funktioniert sie nur, wenn ein Skript mit einem Event money() hinzugefügt wird. -Das liegt daran, dass Einwohner meist erwarten, dass Objekte irgendwie -reagieren, wenn ihnen Geld gezahlt wird. + Achtung: Die Klick-Aktion 'Objekt bezahlen' wurde definiert, sie +funktioniert aber nur, wenn ein Skript mit einem money() Ereignis hinzugefügt wird. + + Beim Einrichten von Events mit 'Objektbezahlung' ohne Geld + - Dieses Objekt weist keine Elemente auf, die Sie kopieren dürfen. + Sie haben keine Berechtigung zum Kopieren von Elementen in diesem Objekt. - + - Zu [URL], -um Transaktionsdetails anzuzeigen? + Zur Second Life-Website, um Ihre Kontostatistik anzuzeigen? - - + - Use this tool to report violations of the Terms of Service and Community Standards. See: -http://secondlife.com/corporate/tos.php -http://secondlife.com/corporate/cs.php - -All reported abuses of the Terms of Service and Community Standards -are investigated and resolved. You will receive an email informing you -of the resolution when it occurs. -You can also view the incident resolution on the Police Blotter at: - + Die Support-Website von Second Life öffnen? + + + Bei Besuch der Second Life Support-Website. + + + + + + + Verwenden Sie dieses Tool, um Verletzungen der Servicebedingungen +und Community-Standards zu melden. Siehe: +- +http://secondlife.com/corporate/tos.php +http://secondlife.com/corporate/cs.php +- +Alle gemeldeten Verletzungen der Servicebedingungen und Community-Standards +werden geprüft und geklärt. Sie werden per E-Mail über die +Klärung informiert. Sie können den Prozess auch im +Police Blotter verfolgen: +- http://secondlife.com/community/blotter.php + + + WICHTIG: Diese Meldung wird an den Eigentümer der Region gesendet, in der Sie sich gerade befinden, nicht an Linden Lab. +- +Als besonderen Service für Einwohner und Besucher übernimmt der Eigentümer dieser Region die Bearbeitung aller anfallenden Meldungen. Von diesem Standort aus eingereichte Meldungen werden nicht von Linden Lab bearbeitet. Der Eigentümer der Region bearbeitet Meldungen auf Grundlage der Richtlinien, die im für diese Region geltenden Grundstücksvertrag festgelegt sind. (Den Vertrag können Sie unter 'Welt' > 'Land-Info' einsehen.) +- +Das Resultat, das sich aus dieser Meldung ergibt, betrifft nur diese Region; der Einwohnerzugang zu anderen Bereichen von Second Life ist davon nicht betroffen. Nur Linden Lab kann den Zugang zu Second Life beschränken. + + - Use this tool to report technical features that do not perform -as described or expected. All bug reports are investigated and -resolved. No email response will be sent, you may reply to the -auto-response email to add more details to your report. -If you are having a technical difficulty, please contact Support at: - + Verwenden Sie dieses Tool *nur*, um technische Features zu melden, +die nicht wie beschrieben oder erwartet funktionieren. Bitte machen +Sie so viele Angaben wie möglich. Sie können auf die automatische +Antwort-E-Mail antworten, um Ihre Meldung noch zu ergänzen. +Alle gemeldeten Fehler werden geprüft und bewertet. Sie erhalten keine persönliche Antwort auf Ihre E-Mail. +- +Bei technischen Problemen wenden Sie sich bitte an den Support unter: http://secondlife.com/community/support.php +- +Hinweis: Unvollständige Meldungen werden nicht bearbeitet. - Bitte wählen Sie eine Kategorie für diesen Missbrauchsbericht. + Wählen Sie eine Missbrauchskategorie aus. -Wenn Sie eine Kategorie wählen, hilft uns das, Missbrauchsberichte einzuordnen und zu bearbeiten. +Die Angabe einer Kategorie hilft uns bei der Bearbeitung des Berichts. - Bitte wählen Sie eine Kategorie für diesen Bug. + Wählen Sie eine Fehler-Kategorie aus. -Wenn Sie eine Kategorie wählen, hilft uns das, Bug-Berichte einzuordnen und zu bearbeiten. +Die Angabe einer Kategorie hilft uns bei der Bearbeitung des Berichts. - Bitte geben Sie den Namen des missbrauchenden Benutzers ein. + Geben Sie den Namen des Täters ein. -Wenn ein genauer Wert eingegeben wird, hilft uns das, Missbrauchsberichte einzuordnen und zu bearbeiten. +Eine genaue Angabe hilft uns, Fälle von Missbrauch zu ahnden. - Bitte geben Sie den Ort des stattgefundenen Missbrauchs ein. + Bitte geben Sie den Ort an, an dem der Missbrauch stattgefunden hat. -Wenn ein genauer Wert eingegeben wird, hilft uns das, Missbrauchsberichte einzuordnen und zu bearbeiten. +Eine genaue Angabe hilft uns, Fälle von Missbrauch zu ahnden. - Bitte geben Sie eine Zusammenfassung des stattgefundenen Missbrauchs ein. + Bitte geben Sie eine Zusammenfassung des Vorfalls ein. -Wenn eine genaue Zusammenfassung eingegeben wird, hilft uns das, Missbrauchsberichte einzuordnen und zu bearbeiten. +Eine genaue Zusammenfassung hilft uns, Fälle von Missbrauch zu ahnden. - Bitte geben Sie eine Zusammenfassung des Bug ein. + Bitte geben Sie eine Zusammenfassung des Fehlers ein. -Wenn eine genaue Zusammenfassung eingegeben wird, hilft uns das, Bug-Berichte einzuordnen und zu bearbeiten. +Eine genaue Zusammenfassung hilft uns, Fehler schneller zu beseitigen. - Bitte geben Sie eine detaillierte Beschreibung des stattgefundenen Missbrauchs ein. -Seien Sie so spezifisch wie möglich, einschließlich Namen und Details -für den Vorfall, den Sie melden. + Bitte geben Sie eine ausführliche Beschreibung des Vorfalls ein, +möglichst genau, mit Namen und Einzelheiten des gemeldeten +Missbrauchs. -Wenn eine genaue Beschreibung eingegeben wird, hilft uns das, Missbrauchsberichte einzuordnen und zu bearbeiten. +Eine genaue Beschreibung hilft uns, Fälle von Missbrauch zu ahnden. - Bitte geben Sie eine detaillierte Beschreibung des Bug ein. -Seien Sie so spezifisch wie möglich und schließen Sie die Schritte -zur Reproduzierung des Bug wenn möglich ein. + Bitte geben Sie eine ausführliche Fehlerbeschreibung ein, +möglichst genau und mit Schritten zur Reproduktion des Fehlers, +sofern möglich. -Wenn eine genaue Beschreibung eingegeben wird, hilft uns das, Bug-Berichte einzuordnen und zu bearbeiten. +Eine genaue Beschreibung hilft uns, Fehler schneller zu beseitigen. - Liebe Einwohner, + Sehr geehrte(r) Einwohner(in), -Berichte über Copyright-Verletzungen können nur wie beschrieben - http://secondlife.com/corporate/dmca.php eingereicht werden. +Meldungen über Urheberrechtsverletzungen können nur auf +http://secondlife.com/corporate/dmca.php eingereicht werden. -Berichte über Copyright-Verletzungen werden automatischverworfen, wenn sie mit Funktion 'Missbrauch melden' -eingereicht werden. Falls Ihr Bericht sich nicht auf Copyright-Verletzungen bezieht, -können Sie dieses Fenster schließen und Ihren Bericht einreichen. +Meldungen über Urheberrechtsverletzungen, die über +'Missbrauch melden' eingereicht wurden, werden automatisch +gelöscht. Wenn Sie keine Urheberrechtsverletzung melden möchten, +können Sie dieses Fenster schließen und mit dem Einreichen Ihrer Meldung fortfahren. -Vielen Dank! +Vielen Dank, Linden Lab - Die folgenden erforderlichen Komponenten fehlen aus [FLOATER]: + Die folgenden erforderlichen Komponenten fehlen in [FLOATER]: [COMPONENTS] - An diesem Punkt Ihres Körpers ist bereits ein Objekt angebracht. + An dieser Körperstelle ist bereits ein Objekt angebracht. Möchten Sie es mit dem ausgewählten Objekt ersetzen? + + Beim Wechseln von Anhängen + - + - Sie sind im Belegt-Modus, das bedeutet, dass Sie keine -Objekte erhalten, die im Austausch gegen -diese Zahlung angeboten werden. + Sie sind im Beschäftigt-Modus, sodass +Sie im Austausch für diese Zahlung keine +Objekte erhalten können. -Möchten Sie den Belegt-Modus verlassen, bevor -Sie diese Transaktion abschließen? +Möchten Sie den Bechäftigt-Modus verlassen, +bevor Sie diese Transaktion abschließen? + + + Beim Bezahlen einer Person oder eines Objekts im Beschäftigt-Modus + + + + + + + Möchten Sie den Inhalt Ihres Papierkorbs +wirklich löschen? - + + + + + Möchten Sie Ihren Browser-Cache +wirklich löschen? + + - + + + + Möchten Sie Ihre Cookies +wirklich löschen? + + + + + + + Möchten Sie den Inhalt Ihres Fundstücke-Ordners +wirklich permanent löschen? + + + Beim Leeren von Inventar und Fundstückeordner- + + + - + + + Die folgende SLURL wurde in die Zwischenablage kopiert: + + [SLURL] + + Veröffentlichen Sie sie auf einer Website, um anderen den Zugang zu diesem Ort + zu erleichtern, oder testen Sie sie, indem Sie sie in die Adressleiste Ihres Browsers kopieren. + + + Beim Kopieren einer SLURL in die Zwischenablage + + + + + Fehler beim Starten einer neuen IM-Sitzung mit [RECIPIENT]. + [REASON] + + + + + + Fehler beim Starten einer neuen IM-Sitzung mit [RECIPIENT]. + [REASON] + + + + + + Fehler [EVENT] [RECIPIENT]. + [REASON] + + + + + + Ihre IM-Sitzung mit [NAME] muss beendet werden. + [REASON] + + + + + + Fehler beim Starten einer neuen Chat-Sitzung mit [RECIPIENT]. + [REASON] + + + + + + Fehler beim Starten einer neuen Chat-Sitzung mit [RECIPIENT]. + [REASON] + + + + + + Fehler [EVENT] [RECIPIENT]. + [REASON] + + + + + + Ihre Chat-Sitzung mit [NAME] muss beendet werden. + [REASON] + + + + + + Objekte können nicht gekauft werden, + wenn sie Teil eines Anhangs sind. + + + + + Granting this request gives a script ongoing permission to take Linden dollars (L$) from your account. To revoke this permission, the object's owner must delete the object or reset the scripts in the object. + + + + - Are you sure you want to permanently remove -the contents of your Trash folder? + Möchten Sie das neu erstellte Kleidungsstück automatisch anziehen? + + Neue Kleidung automatisch tragen + diff --git a/linden/indra/newview/skins/xui/de/floater_about.xml b/linden/indra/newview/skins/xui/de/floater_about.xml index b35a7ee..468f1b9 100644 --- a/linden/indra/newview/skins/xui/de/floater_about.xml +++ b/linden/indra/newview/skins/xui/de/floater_about.xml @@ -1,13 +1,13 @@ - + - Second Life wird zu Ihnen gebracht von: Philip, Andrew, Tessa, Cory, Frank, James, Doug, Hunter, Richard, John, Eric, Avi, AaronB, AaronY, Ian, Peter, Mark, Robin, Stephen, Tracy, Ryan, Alberto, Haney, Tanya, JimJ, Dan, Ben, Stephanie, Tim, Evan, Catherine, Colin, Chris, Reuben, Charity, Jeska, James, JonHenry, Kelly, Callum, Char, Daniel, DavidF, Don, Jeff, Lauren, Lee, Michael, Ramzi, Vektor, Steve, TomY, Tess, Kona, Brent, Clarissa, PeterP, Jesse, Annette, Cyn, Blue, Ginsu, Jonathan, Karen, Adam, Nova, Deana, Lizzie, Patsy, DavidK, Isaac, Pathfinder, Monroe, Jill, Benny, Altruima, Rheya, Jennifer, Jack, DaveP, Brad, Mick, Babbage, Elisabeth, Brian, Beth, Data, Ethan, Wendy, Nicole, Sky, Jeffrey, Zero, Coffee, Tesla, Kenny, Makiko, Nigel, Teeple, Lucy, Mia, Dee, Guy, Harry, Liana, Branka, Jimbo, Aura, Vasuda, SarahD, bethanye, Torley, Runitai, MikeS, PaulM, Milo, Hermia, JoeM, Melanie, Rejean, DSmith, SMiller, Susan, Jose, DongYun, Justin, Andrey, Syrah, Donovan, Henrik, Nora, Lexie, AC, Donna, ChrisC, Alex, Leyla, Kyle, Mathew, Devin, Joshua, DanC, Jessica, Harmony, Claudia, Tramel, Glenn, Betsy, Fritz, Jun, Adam, Cassandra, Ken, RyanW und vielen anderen. + Second Life wird Ihnen präsentiert von Philip, Andrew, Tessa, Cory, Frank, James, Doug, Hunter, Richard, John, Eric, Avi, AaronB, AaronY, Ian, Peter, Mark, Robin, Stephen, Tracy, Ryan, Alberto, Haney, Tanya, JimJ, Dan, Ben, Stephanie, Tim, Evan, Catherine, Colin, Chris, Reuben, Charity, Jeska, James, JonHenry, Kelly, Callum, Char, Daniel, DavidF, Don, Jeff, Lauren, Lee, Michael, Ramzi, Vektor, Steve, TomY, Tess, Kona, Brent, Clarissa, PeterP, Jesse, Annette, Cyn, Blue, Ginsu, Jonathan, Karen, Adam, Nova, Deana, Lizzie, Patsy, DavidK, Isaac, Pathfinder, Monroe, Jill, Benny, Altruima, Rheya, Jennifer, Jack, DaveP, Brad, Mick, Babbage, Elisabeth, Brian, Beth, Data, Ethan, Wendy, Nicole, Sky, Jeffrey, Zero, Coffee, Tesla, Kenny, Makiko, Nigel, Teeple, Lucy, Mia, Dee, Guy, Harry, Liana, Branka, Jimbo, Aura, Vasuda, SarahD, bethanye, Torley, Runitai, MikeS, PaulM, Milo, Hermia, JoeM, Melanie, Rejean, DSmith, SMiller, Susan, Jose, DongYun, Justin, Andrey, Syrah, Donovan, Henrik, Nora, Lexie, AC, Donna, ChrisC, Alex, Leyla, Kyle, Mathew, Devin, Joshua, DanC, Jessica, Harmony, Claudia, Tramel, Glenn, Betsy, Fritz, Jun, Adam, Cassandra, Ken, RyanW, Spike, Varas, Andy, Luke, RobLa, Chiyo, JohnZ, Dustin, George, Del, PeterP, Migyeong, Matthew, RMullane, CChampion, JTurbin, JamesC, Viola, Lightfoot, Jacqui, Sturm, Adrian, Buttercup, Alfred, Sunil, Alfred, Noel, Irfan, Jill, Yool, Jane, Yuki, Yoz, Matthew, Arthur, Jennifer, Karl, Brian, Ben, Janine, Christopher, Madhavi, Everett, Anthony, Joon, Jake, sean, Adreanne, Stephany, KellyJo, Jeremy, Pramod, Joshua, Sean, Christopher, Amy, Ceren, Katherine, jon, Sudheendra, James, Stephan, Kari, Kartic, Todd, Thomas, Joki, Rebecca, Belinda, Bert, Roger, Bridie, Kristi, Brian, Maria, John, Aric, Nathanel, Melinda, Darrell, Jennifer, Sandy, Greg, Rob, Brad, Chris, Eric, Palmer, Asi, Katja, Lisa, Minda, Jen, Aaron, Bryan, Mark, Jonathan, Jamie, Laurel, William, Matthew, Steve, David, Remy, James, Tim, Lee, Brian, Ashlei, Sam, Mike, Ethan, Austin, Wanda, Paul, Brian, Rachel, Valentyn, Emma Williams, Autum, Steven, Laley, Charles, Jessica, Sue, Gillian, CG, Kip, Kristen, Shamiran, Blake, Brett, Erica, Kent, Joel, Plexus, Twilight, Joppa und vielen anderen. -Vielen Dank den folgenden Einwohnern, die uns geholfen haben, die bisher beste Version zu entwickeln: Kyrah Abattoir, Icesis Anansi, Clifton Antonelli, Nargus Asturias, Justizin Austinmer, Drake Bacon, Bitzer Balderdash, McWheelie Baldwin, SuezanneC Baskerville, Sweetheart Baskerville, Logan Bauer, Malarthi Behemoth, phoenix Behemoth, Eva Bellambi, Samgame Bertrand, Woody Blair, Tin Bling, Bibi Book, Barney Boomslang, Eric Boyer, Chromal Brodsky, Kerian Bunin, Lara Bunin, BigRick Byrd, Jillian Callahan, Hypatia Callisto, Frans Charming, nathalie Christensen, Francis Chung, pizzaguy Clutterbuck, Evo Commons, Entity Cosmo, Grazel Cosmo, Tiger Crossing, Fremont Cunningham, Jaki Daligdig, Sugar Darling, Todd David, Norman Desmoulins, Gxeremio Dimsum, Happy Dimsum, Kim Dingo, Roy Domela, Cory Edo, Delu Elytis, DBDigital Epsilon, Leeza Everett, Garth FairChang, Snowflake Fairymeadow, Khamon Fate, lex Fitzcarraldo, Kitto Flora, Angel Fluffy, CrystalShard Foo, Raudf Fox, Govindira Galatea, Rizpah Galatea, Tre Giles, Gattz Gilman, Kex Godel, Armandi Goodliffe, Tsu Goodliffe, Nickolas Goodman, Damen Gorilla, Nytemyst Grace, Mhaijik Guillaume, Gleeb Gupte, Ebonfire Harbinger, Bethanee Heaney, Jenny Hicks, Sandling Honey, Victoria Jacques, Adso Krogstad, Travis Lambert, simon Lameth, Duffy Langdon, Aaron Levy, Jade Lily, Gwyneth Llewelyn, Lola Lollipop, Michi Lumin, KaiLastOfTheBrunnenG Macdonald, Jesse Malthus, Herry Maltz, Seth Mandelbrot, Raavi Mann, Shirley Marquez, Dnate Mars, Ima Mechanique, Hawk Mendicant, Mercury Metropolitan, Haravikk Mistral, Trent Mondrian, Nexus Nash, Seraph Nephilim, Lewis Nerd, Aurael Neurocam, Lex Neva, Prokofy Neva, Seagel Neville, Kate Nicholas, Didde Nielsen, Richard Noonan, crevan Nori, Maczter Oddfellow, vanler Odets, Fat Ogre, Hamncheese Omlet, Strife Onizuka, Panthar Orlowski, Jessica Ornitz, Ron Overdrive, OmniCron Overlord, Dargon Pacer, Kar Parks, Eloise Pasteur, Caliandris Pendragon, Julianna Pennyfeather, Iron Perth, Shawk Pertwee, Mera Pixel, Elle Pollack, Phoenix Psaltery, Hank Ramos, Jon Ree, Tam Ree, Zi Ree, Jon Rolland, BamBam Sachertorte, kai Sachertorte, Mily Sartre, ice Semple, Desmond Shang, DigiKatt Shaw, Felix Sholokhov, Rhyph Somme, Rain Soothsayer, Oz Spade, squeekachu Spearmann, Wesley Spengler, Belaya Statosky, eltee Statosky, Khashai Steinbeck, Draco Steinhardt, Hope Stilman, Ashen Stygian, Seifert Surface, Gigs Taggart, Dolmere Talamasca, JayJay Talamasca, Becky Tardis, Fenris Tardis, Cubey Terra, Osprey Therian, Millie Thompson, John Toonie, Charlene Trudeau, Lyr Tuppakaka, Indy Turner, Luthien Unsung, Random Unsung, Huns Valen, Valdemar Virgo, Gordon Wendt, Mike Westerburg, Wayfinder Wishbringer, Lee Wormser, Aimee Xia, nimrod Yaffle, Yiffy Yaffle, Elle74 Zaftig und viele andere. +Im Gedenken an Jesse Malthus. Du wirst allen in Erinnerung bleiben, die deine Stimme hören durften. +Vielen Dank den folgenden Einwohnern, die uns geholfen haben, dies zur bisher besten Version zu machen: Aces Spade, Adrian Buckler, Adrienne LeShelle, Amanda Ascot, AnnaQuay Heart, Aquamina Khalifa, Arienne Anatine, Aston Hildyard, Ayami Kamachi, Badinage Odets, Biffy Berjis, Bigfox Pye, BigJohn Jade, BigRick Byrd, Brettus Tripsa, Brock Fitzgerald, Broker Allen, Browse by Name, Chiria Celt, Christopher Prudhomme, dale Cao, dale Lynch, Dante Tucker, DaQbet Kish, Dargon Pacer, Darius Antonelli, Deira Llanfair, DeviantBone Xi, Dore Dorado, Englishwob Etchegaray, Enya Masala, Eric Renneville, Fairfax Michinaga, FireFox Bancroft, FOXI Cortes, Frederick Earp, Geo Meek, Gotthilf Fischer, Hallo Loon, Hawk Carter, Hazel Kyrgyz, Hecter Barbosa, Hex Link, Ice Pak, Ideasu Mukerji, Itoku Kamachi, Jared Halleck, Jaykob Carter, Jennifer Drumheller, JensMartin Tomsen, JIAB Boa, Jim Gustafson, JimmyJet Fossett, Joseph Rustamova, Jt Volos, Karilyn Kidomen, Kaysha Sion, Keaton Nacon, Kevin Susenko, Khashai Steinbeck, Kira Cuddihy, Kit Massiel, Kojo Dixon, KUieTSToRm Lightcloud, Kwai Kyong, Kyrtis Daehlie, LazyGunGuy Bartlett, Lewcas Zapedzki, Lioc Cioc, LLIB Utu, Lou Liebknecht, Luca Draken, Maci Homewood, Major Sewell, Mari Todriya, MarieElize Noel, matt27 Churchill, Maverick Miasma, maydaysos Young, Mediaho Ball, Mikayla Gillespie, Mike Faulkland, Modfire Milland, MollyBrown Foxley, Mosley Jewell, Nuahs Zapedzki, Nyx Divine, Panther Farber, Paul Bumi, PrincessNina Prefect, Prio Serpentine, Rainbow Drake, Randall Rall, Randy Kazan, Reinhart Mokeev, Rhyph Somme, Rico Roizman, Ruge Dryke, Ryan Orbit, Safira Rosher, Samantha Bainbridge, Sammy Foxley, Sash Furst, Saturn Ariantho, Sienna Summers, Skye Enoch, Sofie Kanno, Solar Legion, Sonic Oki, Sunra Saenz, Taina Heart, Taryn Sprawl, tenerife Wei, TomDragon Nilsson, Trebla Reve, Trouble Carnell, user1cat Orbit, Vance Merlin, Veritas Variscan, Web Page, Wi3g3ht3s Ihnen, WinDrftr DeFarge, Yuu Nakamichi, Zac Delec, Zed Fairweather, Zimmo Hallard. APR Copyright (C) 2000-2004 The Apache Software Foundation -Cg Copyright (C) 2002, NVIDIA Corporationa. cURL Copyright (C) 1996-2002, Daniel Stenberg, (daniel@haxx.se) expat Copyright (C) 1998, 1999, 2000 Thai Open Source Software Center Ltd. FreeType Copyright (C) 1996-2002, The FreeType Project (www.freetype.org). @@ -20,11 +20,16 @@ OpenSSL Copyright (C) 1998-2002 The OpenSSL Project. SDL Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002 Sam Lantinga SSLeay Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com) xmlrpc-epi Copyright (C) 2000 Epinions, Inc. -zlib Copyright (C) 1995-2002 Jean-loup Gailly and Mark Adler. +zlib Copyright (C) 1995-2002 Jean-loup Gailly und Mark Adler. Alle Rechte vorbehalten. Details siehe licenses.txt. +Voice-Chat-Audiocoding: Polycom(R) Siren14(TM) (ITU-T Empf. G.722.1 Anhang C) -Fehler sind kein Geheimnis, die darf ruhig jeder sehen. + +Mr. Watson - kommen Sie bitte her - ich möchte Sie sehen. + + Sie befinden sich in [POSITION] + diff --git a/linden/indra/newview/skins/xui/de/floater_about_land.xml b/linden/indra/newview/skins/xui/de/floater_about_land.xml index e040e14..37fa2c5 100644 --- a/linden/indra/newview/skins/xui/de/floater_about_land.xml +++ b/linden/indra/newview/skins/xui/de/floater_about_land.xml @@ -1,5 +1,5 @@ - + @@ -18,21 +18,21 @@ Gruppe: -