diff --git a/wpiformat/test/test_includeorder.py b/wpiformat/test/test_includeorder.py index 3734cd94..8bbfb1aa 100644 --- a/wpiformat/test/test_includeorder.py +++ b/wpiformat/test/test_includeorder.py @@ -546,4 +546,20 @@ def test_includeorder(): "#endif" + os.linesep) test.add_latest_input_as_output(True) + # Ensure #ifndef is handled properly + test.add_input("./Test.h", + "#ifndef __APPLE__" + os.linesep + \ + "#include " + os.linesep + \ + "#elif !defined(_WIN32)" + os.linesep + \ + "#include " + os.linesep + \ + "#endif" + os.linesep) + test.add_latest_input_as_output(True) + + # Ensure #ifndef is handled properly + test.add_input("./Test.h", + "#ifndef _WIN32" + os.linesep + \ + "#include " + os.linesep + \ + "#endif" + os.linesep) + test.add_latest_input_as_output(True) + test.run(OutputType.FILE) diff --git a/wpiformat/wpiformat/includeorder.py b/wpiformat/wpiformat/includeorder.py index 58fe9b62..efe8fa22 100644 --- a/wpiformat/wpiformat/includeorder.py +++ b/wpiformat/wpiformat/includeorder.py @@ -222,10 +222,10 @@ def header_sort(self, config_file, lines_list, file_name, start, end, i = start while i < end: - if "#ifdef" in lines_list[i]: + if "#ifdef" in lines_list[i] or "#ifndef" in lines_list[i]: ifdef_count = 1 for j in range(i + 1, end): - if "#ifdef" in lines_list[j]: + if "#ifdef" in lines_list[j] or "#ifndef" in lines_list[j]: ifdef_count += 1 elif "#endif" in lines_list[j]: ifdef_count -= 1 @@ -365,6 +365,7 @@ def run_pipeline(self, config_file, name, lines): # Write lines from beginning of file to headers i = 0 while i < len(lines_list) and ("#ifdef" not in lines_list[i] and + "#ifndef" not in lines_list[i] and "#include" not in lines_list[i]): i += 1 output_list = lines_list[0:i]