aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/newview')
-rw-r--r--linden/indra/newview/llstartup.cpp3
-rw-r--r--linden/indra/newview/llviewermenu.cpp54
-rw-r--r--linden/indra/newview/primbackup.cpp107
-rw-r--r--linden/indra/newview/primbackup.h2
-rw-r--r--linden/indra/newview/skins/default/xui/en-us/menu_pie_object.xml2
-rw-r--r--linden/indra/newview/skins/default/xui/en-us/menu_viewer.xml18
6 files changed, 83 insertions, 103 deletions
diff --git a/linden/indra/newview/llstartup.cpp b/linden/indra/newview/llstartup.cpp
index 9b46054..6839a4f 100644
--- a/linden/indra/newview/llstartup.cpp
+++ b/linden/indra/newview/llstartup.cpp
@@ -2130,7 +2130,6 @@ bool idle_startup()
2130 LLAvatarTracker::instance().addBuddyList(list); 2130 LLAvatarTracker::instance().addBuddyList(list);
2131 } 2131 }
2132 2132
2133 /*
2134 options.clear(); 2133 options.clear();
2135 if(LLUserAuth::getInstance()->getOptions("ui-config", options)) 2134 if(LLUserAuth::getInstance()->getOptions("ui-config", options))
2136 { 2135 {
@@ -2149,7 +2148,7 @@ bool idle_startup()
2149 } 2148 }
2150 } 2149 }
2151 } 2150 }
2152 */ 2151
2153 options.clear(); 2152 options.clear();
2154 bool show_hud = false; 2153 bool show_hud = false;
2155 if(LLUserAuth::getInstance()->getOptions("tutorial_setting", options)) 2154 if(LLUserAuth::getInstance()->getOptions("tutorial_setting", options))
diff --git a/linden/indra/newview/llviewermenu.cpp b/linden/indra/newview/llviewermenu.cpp
index 0146f9e..ba24c16 100644
--- a/linden/indra/newview/llviewermenu.cpp
+++ b/linden/indra/newview/llviewermenu.cpp
@@ -2307,56 +2307,32 @@ class LLObjectEnableExport : public view_listener_t
2307{ 2307{
2308 bool handleEvent(LLPointer<LLEvent> event, const LLSD& userdata) 2308 bool handleEvent(LLPointer<LLEvent> event, const LLSD& userdata)
2309 { 2309 {
2310 LLViewerObject* object = LLSelectMgr::getInstance()->getSelection()->getPrimaryObject(); 2310 LLControlVariable* control =
2311 bool new_value = (object != NULL); 2311 gMenuHolder->findControl(userdata["control"].asString());
2312 if (new_value) 2312
2313 { 2313 LLViewerObject* object =
2314 LLVOAvatar* avatar = find_avatar_from_object(object); 2314 LLSelectMgr::getInstance()->getSelection()->getPrimaryObject();
2315 new_value = (avatar == NULL); 2315
2316 } 2316 if((object != NULL) &&
2317 if(new_value) 2317 (find_avatar_from_object(object) == NULL))
2318 { 2318 {
2319
2320 struct ff : public LLSelectedNodeFunctor 2319 struct ff : public LLSelectedNodeFunctor
2321 { 2320 {
2322 ff(const LLSD& data) : LLSelectedNodeFunctor()
2323 ,userdata(data)
2324 {
2325
2326 }
2327 const LLSD& userdata;
2328 virtual bool apply(LLSelectNode* node) 2321 virtual bool apply(LLSelectNode* node)
2329 { 2322 {
2330 if(gAgent.getID()!=node->mPermissions->getCreator()) 2323 return primbackup::check_perms( node );
2331 {
2332 return false;
2333 }
2334 return true;
2335 } 2324 }
2336 }; 2325 } func;
2337 2326
2338#ifdef LL_GRID_PERMISSIONS 2327 if(LLSelectMgr::getInstance()->getSelection()->applyToNodes(&func,false))
2339
2340 ff * the_ff=new ff(userdata);
2341 if(LLSelectMgr::getInstance()->getSelection()->applyToNodes(the_ff,false))
2342 {
2343 gMenuHolder->findControl(userdata["control"].asString())->setValue(true);
2344 }
2345 else
2346 { 2328 {
2347 gMenuHolder->findControl(userdata["control"].asString())->setValue(false); 2329 control->setValue(true);
2330 return true;
2348 } 2331 }
2349 return true;
2350 } 2332 }
2351 2333
2352 gMenuHolder->findControl(userdata["control"].asString())->setValue(new_value); 2334 control->setValue(false);
2353 return true;
2354#else
2355 }
2356 gMenuHolder->findControl(userdata["control"].asString())->setValue(true);
2357 return true; 2335 return true;
2358#endif
2359
2360 } 2336 }
2361}; 2337};
2362 2338
diff --git a/linden/indra/newview/primbackup.cpp b/linden/indra/newview/primbackup.cpp
index 78fd482..8dbf1df 100644
--- a/linden/indra/newview/primbackup.cpp
+++ b/linden/indra/newview/primbackup.cpp
@@ -350,54 +350,52 @@ void primbackup::pre_export_object()
350 gIdleCallbacks.addFunction(exportworker, NULL); 350 gIdleCallbacks.addFunction(exportworker, NULL);
351} 351}
352 352
353
354// static
355bool primbackup::check_perms( LLSelectNode* node )
356{
357 LLPermissions *perms = node->mPermissions;
358 return (gAgent.getID() == perms->getOwner() &&
359 gAgent.getID() == perms->getCreator() &&
360 (PERM_ITEM_UNRESTRICTED &
361 perms->getMaskOwner()) == PERM_ITEM_UNRESTRICTED);
362}
363
364
353void primbackup::exportworker(void *userdata) 365void primbackup::exportworker(void *userdata)
354{ 366{
355 primbackup::getInstance()->updateexportnumbers(); 367 primbackup::getInstance()->updateexportnumbers();
356 368
357 switch(primbackup::getInstance()->export_state) 369 switch(primbackup::getInstance()->export_state)
358 { 370 {
359 case EXPORT_INIT: 371 case EXPORT_INIT: {
372 primbackup::getInstance()->show();
373 LLSelectMgr::getInstance()->getSelection()->ref();
374
375 struct ff : public LLSelectedNodeFunctor
360 { 376 {
361 primbackup::getInstance()->show(); 377 virtual bool apply(LLSelectNode* node)
362 LLSelectMgr::getInstance()->getSelection()->ref();
363
364 struct ff : public LLSelectedNodeFunctor
365 {
366 virtual bool apply(LLSelectNode* node)
367 {
368 if(gAgent.getID()!=node->mPermissions->getOwner())
369 {
370 #ifdef LL_GRID_PERMISSIONS
371 return false;
372 #else
373 return true;
374 #endif
375 }
376 else if(581632==node->mPermissions->getMaskOwner() || 2147483647==node->mPermissions->getMaskOwner())
377 {
378 return true;
379 }
380 return false;
381 }
382 } func;
383
384 if(LLSelectMgr::getInstance()->getSelection()->applyToNodes(&func,false))
385 primbackup::getInstance()->export_state=EXPORT_STRUCTURE;
386 else
387 { 378 {
388 llwarns<<"Incorrect permission to export"<<llendl; 379 return primbackup::check_perms( node );
389 primbackup::getInstance()->export_state=EXPORT_DONE;
390 primbackup::getInstance()->close();
391 gIdleCallbacks.deleteFunction(exportworker);
392 LLSelectMgr::getInstance()->getSelection()->unref();
393
394 } 380 }
395 break; 381 } func;
396 }
397 382
383 if(LLSelectMgr::getInstance()->getSelection()->applyToNodes(&func,false))
384 {
385 primbackup::getInstance()->export_state=EXPORT_STRUCTURE;
386 }
387 else
388 {
389 llwarns << "Incorrect permission to export" << llendl;
390 primbackup::getInstance()->export_state=EXPORT_DONE;
391 primbackup::getInstance()->close();
392 gIdleCallbacks.deleteFunction(exportworker);
393 LLSelectMgr::getInstance()->getSelection()->unref();
394 }
398 break; 395 break;
399 case EXPORT_STRUCTURE: 396 }
400 { 397
398 case EXPORT_STRUCTURE: {
401 struct ff : public LLSelectedObjectFunctor 399 struct ff : public LLSelectedObjectFunctor
402 { 400 {
403 virtual bool apply(LLViewerObject* object) 401 virtual bool apply(LLViewerObject* object)
@@ -405,7 +403,7 @@ void primbackup::exportworker(void *userdata)
405 object->boostTexturePriority(TRUE); 403 object->boostTexturePriority(TRUE);
406 LLViewerObject::child_list_t children = object->getChildren(); 404 LLViewerObject::child_list_t children = object->getChildren();
407 children.push_front(object); //push root onto list 405 children.push_front(object); //push root onto list
408 LLSD prim_llsd=primbackup::getInstance()->prims_to_llsd(children); 406 LLSD prim_llsd=primbackup::getInstance()->prims_to_llsd(children);
409 LLSD stuff; 407 LLSD stuff;
410 stuff["root_position"] = object->getPosition().getValue(); 408 stuff["root_position"] = object->getPosition().getValue();
411 stuff["root_rotation"] = ll_sd_from_quaternion(object->getRotation()); 409 stuff["root_rotation"] = ll_sd_from_quaternion(object->getRotation());
@@ -421,7 +419,8 @@ void primbackup::exportworker(void *userdata)
421 419
422 break; 420 break;
423 } 421 }
424 case EXPORT_TEXTURES: 422
423 case EXPORT_TEXTURES: {
425 if(primbackup::getInstance()->m_nexttextureready==false) 424 if(primbackup::getInstance()->m_nexttextureready==false)
426 return; 425 return;
427 426
@@ -435,23 +434,25 @@ void primbackup::exportworker(void *userdata)
435 } 434 }
436 435
437 primbackup::getInstance()->export_next_texture(); 436 primbackup::getInstance()->export_next_texture();
438 break; 437 break;
438 }
439 439
440 case EXPORT_LLSD: 440 case EXPORT_LLSD: {
441 { 441 // Create a file stream and write to it
442 // Create a file stream and write to it 442 llofstream export_file(primbackup::getInstance()->file_name);
443 llofstream export_file(primbackup::getInstance()->file_name); 443 LLSDSerialize::toPrettyXML(primbackup::getInstance()->llsd, export_file);
444 LLSDSerialize::toPrettyXML(primbackup::getInstance()->llsd, export_file); 444 export_file.close();
445 export_file.close(); 445 primbackup::getInstance()->m_nexttextureready=true;
446 primbackup::getInstance()->m_nexttextureready=true; 446 primbackup::getInstance()->export_state=EXPORT_TEXTURES;
447 primbackup::getInstance()->export_state=EXPORT_TEXTURES;
448 }
449 break; 447 break;
450 case EXPORT_DONE: 448 }
451 llinfos<<"Backup complete"<<llendl 449
452 gIdleCallbacks.deleteFunction(exportworker); 450 case EXPORT_DONE: {
453 primbackup::getInstance()->close(); 451 llinfos << "Backup complete" << llendl;
452 gIdleCallbacks.deleteFunction(exportworker);
453 primbackup::getInstance()->close();
454 break; 454 break;
455 }
455 } 456 }
456} 457}
457 458
diff --git a/linden/indra/newview/primbackup.h b/linden/indra/newview/primbackup.h
index fddc35f..cbd757a 100644
--- a/linden/indra/newview/primbackup.h
+++ b/linden/indra/newview/primbackup.h
@@ -18,6 +18,8 @@ class primbackup : public LLFloater
18 //Static accessor 18 //Static accessor
19 static primbackup* getInstance(); 19 static primbackup* getInstance();
20 20
21 static bool check_perms( LLSelectNode* node );
22
21 virtual ~primbackup(); 23 virtual ~primbackup();
22 24
23 //Floater stuff 25 //Floater stuff
diff --git a/linden/indra/newview/skins/default/xui/en-us/menu_pie_object.xml b/linden/indra/newview/skins/default/xui/en-us/menu_pie_object.xml
index 15cdc9e..2c7ca3c 100644
--- a/linden/indra/newview/skins/default/xui/en-us/menu_pie_object.xml
+++ b/linden/indra/newview/skins/default/xui/en-us/menu_pie_object.xml
@@ -44,7 +44,7 @@
44 <on_enable function="Object.EnableReturn" /> 44 <on_enable function="Object.EnableReturn" />
45 </menu_item_call> 45 </menu_item_call>
46 <pie_menu label="More &gt;" name="Rate Menu"> 46 <pie_menu label="More &gt;" name="Rate Menu">
47 <menu_item_call label="Backup" enabled="false" hidden="false" 47 <menu_item_call label="Export" enabled="false" hidden="false"
48 mouse_opaqu="true" name="Export"> 48 mouse_opaqu="true" name="Export">
49 <on_click function="Object.Export" /> 49 <on_click function="Object.Export" />
50 <on_enable function="Object.EnableExport" /> 50 <on_enable function="Object.EnableExport" />
diff --git a/linden/indra/newview/skins/default/xui/en-us/menu_viewer.xml b/linden/indra/newview/skins/default/xui/en-us/menu_viewer.xml
index 92b7008..9da0ec5 100644
--- a/linden/indra/newview/skins/default/xui/en-us/menu_viewer.xml
+++ b/linden/indra/newview/skins/default/xui/en-us/menu_viewer.xml
@@ -8,14 +8,6 @@
8 8
9 <menu name="File" create_jump_keys="true" label="File" 9 <menu name="File" create_jump_keys="true" label="File"
10 opaque="true" tear_off="true"> 10 opaque="true" tear_off="true">
11 <menu_item_call enabled="false" hidden="false" label="Import" mouse_opaque="true" name="Import">
12 <on_click function="Object.Import" />
13 <on_enable function="Object.EnableImport" />
14 </menu_item_call>
15 <menu_item_call enabled="false" hidden="false" label="Upload + Import" mouse_opaque="true" name="Import">
16 <on_click function="Object.ImportUpload" />
17 <on_enable function="Object.EnableImport" />
18 </menu_item_call>
19 <menu_item_call name="Upload Image" 11 <menu_item_call name="Upload Image"
20 label="Upload Image (L$[COST])..." 12 label="Upload Image (L$[COST])..."
21 shortcut="control|U"> 13 shortcut="control|U">
@@ -37,6 +29,16 @@
37 <on_click function="File.UploadBulk" userdata="" /> 29 <on_click function="File.UploadBulk" userdata="" />
38 </menu_item_call> 30 </menu_item_call>
39 <menu_item_separator /> 31 <menu_item_separator />
32 <menu_item_call name="Import" label="Import" enabled="false">
33 <on_click function="Object.Import" />
34 <on_enable function="Object.EnableImport" />
35 </menu_item_call>
36 <menu_item_call name="Upload + Import" label="Upload + Import"
37 enabled="false">
38 <on_click function="Object.ImportUpload" />
39 <on_enable function="Object.EnableImport" />
40 </menu_item_call>
41 <menu_item_separator />
40 <menu_item_call name="Close Window" 42 <menu_item_call name="Close Window"
41 label="Close Window" 43 label="Close Window"
42 shortcut="control|W"> 44 shortcut="control|W">