CloneSelection: don't overwrite names of target/targetname
by holding Shift while pressing space, you get the old behaviour back git-svn-id: svn://svn.icculus.org/netradiant/trunk@145 61c419a2-8eb2-4b30-bcec-8cead039b335
This commit is contained in:
parent
a79c1a21aa
commit
c8a08caf81
|
|
@ -1186,7 +1186,9 @@ void SelectFaceMode()
|
||||||
|
|
||||||
class CloneSelected : public scene::Graph::Walker
|
class CloneSelected : public scene::Graph::Walker
|
||||||
{
|
{
|
||||||
|
bool doFixNames;
|
||||||
public:
|
public:
|
||||||
|
CloneSelected(bool d): doFixNames(d) { }
|
||||||
bool pre(const scene::Path& path, scene::Instance& instance) const
|
bool pre(const scene::Path& path, scene::Instance& instance) const
|
||||||
{
|
{
|
||||||
if(path.size() == 1)
|
if(path.size() == 1)
|
||||||
|
|
@ -1223,9 +1225,9 @@ public:
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
void Scene_Clone_Selected(scene::Graph& graph)
|
void Scene_Clone_Selected(scene::Graph& graph, bool doFixNames)
|
||||||
{
|
{
|
||||||
graph.traverse(CloneSelected());
|
graph.traverse(CloneSelected(doFixNames));
|
||||||
|
|
||||||
Map_mergeClonedNames();
|
Map_mergeClonedNames();
|
||||||
}
|
}
|
||||||
|
|
@ -1297,7 +1299,20 @@ void Selection_Clone()
|
||||||
{
|
{
|
||||||
UndoableCommand undo("cloneSelected");
|
UndoableCommand undo("cloneSelected");
|
||||||
|
|
||||||
Scene_Clone_Selected(GlobalSceneGraph());
|
Scene_Clone_Selected(GlobalSceneGraph(), false);
|
||||||
|
|
||||||
|
//NudgeSelection(eNudgeRight, GetGridSize(), GlobalXYWnd_getCurrentViewType());
|
||||||
|
//NudgeSelection(eNudgeDown, GetGridSize(), GlobalXYWnd_getCurrentViewType());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Selection_Clone_FixNames()
|
||||||
|
{
|
||||||
|
if(GlobalSelectionSystem().Mode() == SelectionSystem::ePrimitive)
|
||||||
|
{
|
||||||
|
UndoableCommand undo("cloneSelected");
|
||||||
|
|
||||||
|
Scene_Clone_Selected(GlobalSceneGraph(), true);
|
||||||
|
|
||||||
//NudgeSelection(eNudgeRight, GetGridSize(), GlobalXYWnd_getCurrentViewType());
|
//NudgeSelection(eNudgeRight, GetGridSize(), GlobalXYWnd_getCurrentViewType());
|
||||||
//NudgeSelection(eNudgeDown, GetGridSize(), GlobalXYWnd_getCurrentViewType());
|
//NudgeSelection(eNudgeDown, GetGridSize(), GlobalXYWnd_getCurrentViewType());
|
||||||
|
|
@ -3393,6 +3408,7 @@ void MainFrame_Construct()
|
||||||
GlobalCommands_insert("Paste", FreeCaller<Paste>(), Accelerator('V', (GdkModifierType)GDK_CONTROL_MASK));
|
GlobalCommands_insert("Paste", FreeCaller<Paste>(), Accelerator('V', (GdkModifierType)GDK_CONTROL_MASK));
|
||||||
GlobalCommands_insert("PasteToCamera", FreeCaller<PasteToCamera>(), Accelerator('V', (GdkModifierType)GDK_MOD1_MASK));
|
GlobalCommands_insert("PasteToCamera", FreeCaller<PasteToCamera>(), Accelerator('V', (GdkModifierType)GDK_MOD1_MASK));
|
||||||
GlobalCommands_insert("CloneSelection", FreeCaller<Selection_Clone>(), Accelerator(GDK_space));
|
GlobalCommands_insert("CloneSelection", FreeCaller<Selection_Clone>(), Accelerator(GDK_space));
|
||||||
|
GlobalCommands_insert("CloneSelectionAndFixNames", FreeCaller<Selection_Clone_FixNames>(), Accelerator(GDK_space, (GdkModifierType)GDK_SHIFT_MASK));
|
||||||
GlobalCommands_insert("DeleteSelection", FreeCaller<deleteSelection>(), Accelerator(GDK_BackSpace));
|
GlobalCommands_insert("DeleteSelection", FreeCaller<deleteSelection>(), Accelerator(GDK_BackSpace));
|
||||||
GlobalCommands_insert("ParentSelection", FreeCaller<Scene_parentSelected>());
|
GlobalCommands_insert("ParentSelection", FreeCaller<Scene_parentSelected>());
|
||||||
GlobalCommands_insert("UnSelectSelection", FreeCaller<Selection_Deselect>(), Accelerator(GDK_Escape));
|
GlobalCommands_insert("UnSelectSelection", FreeCaller<Selection_Deselect>(), Accelerator(GDK_Escape));
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user