CLion 2016.3 Help

Safe Delete

On this page:

Introduction

The Safe Delete refactoring lets you safely remove files from the source code. This refactoring prevents you from uncontrolled deleting of declarations that have usages in the source code.

To make sure that deletion is safe, CLion looks for the usages of the file being deleted. If such usages are found, you can explore them and make the necessary corrections in your code before the symbol is actually deleted.

Performing the refactoring

  1. Select the item to be deleted.
  2. Do one of the following:
    • Press Alt+Delete.
    • Select Refactor | Safe Delete from the main or the context menu.
    • Select Refactor | Refactor This from the main menu (Ctrl+Shift+Alt+T), and select Safe Delete.
  3. In the Safe Delete dialog, select the necessary options and click OK.
  4. If the refactoring is potentially unsafe, the Usages Detected dialog opens.
    /help/img/idea/cl_safedeleteUsages.png
    • View Usages. Click this button to see where in your code the item you are about to delete is used. As a result, the Find tool window opens.
      /help/img/idea/cl_safedeleteView.png

      Analyze your code and make the necessary corrections. Then click Do Refactor. (If you want to rerun the refactoring from its start, click Rerun Safe Delete. CLion will check if the refactoring is safe once more.)

    • Delete Anyway. Click this button to delete the item without looking at its usages.

Safe Delete for File and CMake

When deleting files, in case these files are referenced as the arguments of the particular CMake commands, Safe Delete is performed. Upon deleting, the IDE performs the automatic CMake reload, if the autoreload feature is enabled.
  • In case the file you are going to delete is the only argument of some CMake command (for example add_executable(foobar foo.cpp)), this command may become incorrect after deletion.
  • The described behaviour is supported for the following list of CMake commands:
    • add_executable();
    • add_library();
    • set();
    • add_custom_target_command();
    • fltk_wrap_ui();
    • qt_wrap_cpp();
    • qt_wrap_ui():
    • set_property();
    • set_source_files_properties();
    • try_compile().

See Also

Last modified: 22 November 2016