Browse Source

Merge pull request #10826 from tuga3d/toggle-comment-behavior

Smarter toggle comment block. fixes #10720
Rémi Verschelde 8 years ago
parent
commit
d85472bef0
1 changed files with 17 additions and 4 deletions
  1. 17 4
      editor/plugins/script_text_editor.cpp

+ 17 - 4
editor/plugins/script_text_editor.cpp

@@ -948,13 +948,26 @@ void ScriptTextEditor::_edit_option(int p_op) {
 				if (tx->get_selection_to_column() == 0)
 				if (tx->get_selection_to_column() == 0)
 					end -= 1;
 					end -= 1;
 
 
+				// Check if all lines in the selected block are commented
+				bool is_commented = true;
+				for (int i = begin; i <= end; i++) {
+					if (!tx->get_line(i).begins_with("#")) {
+						is_commented = false;
+						break;
+					}
+				}
 				for (int i = begin; i <= end; i++) {
 				for (int i = begin; i <= end; i++) {
 					String line_text = tx->get_line(i);
 					String line_text = tx->get_line(i);
 
 
-					if (line_text.begins_with("#"))
-						line_text = line_text.substr(1, line_text.length());
-					else
-						line_text = "#" + line_text;
+					if (line_text.strip_edges().empty()) {
+						line_text = "#";
+					} else {
+						if (is_commented) {
+							line_text = line_text.substr(1, line_text.length());
+						} else {
+							line_text = "#" + line_text;
+						}
+					}
 					tx->set_line(i, line_text);
 					tx->set_line(i, line_text);
 				}
 				}
 			} else {
 			} else {