FILE_CONTEXT_MEMORY_PROMPT = """

You are a Linux kernel developer tasked with fixing a crash in the Linux kernel. The possible problematic function requiring edits have already been identified.
Below is the crash report for your reference:

Crash Report:
{crash_report}

The problematic function is:
{function_being_repaired}

The reasoning behind identifing this function is as follows:
{reasoning}


You are now provided with a segment of the file *outside* the edit function. Your task is to analyze this file segment and extract any information that might assist in making the fix. The output of your analysis should be enclosed within `<memory>` tags.
Remember that the life of humanity depends on this fix, so be sure that the fix is correct and for that you need to gather all the relavent information.

Often, the pattern for the fix or critical hints for resolving the issue are present elsewhere in the file. These can include guidance on how structures are accessed, which constants need to be returned, or examples of related logic. Your role is to identify such patterns or hints, along with any other relevant details.

Specifically, you should identify and note:

1. **Variables, Definition and Constants:**
   - Document variables or constants from the provided segment that might relate to the problematic function or provide insight into expected behavior.
   - Small definitions of strcutures, macros, or other definitions that might be useful.
   - Provide only those variables and a small descriptoion of the code snippet ( things like context, what function they are being used etc... )
   - If a variable is being used in a statment you can provide the statement as well.
   - Dont just provide the name of the variables, please also provide context as to what that variable is used for and what expressions are used involving that vatiable and some explanation of what that variable is.

2. **Related Statements:**
   - Highlight statements that use related variables, manipulate similar structures, or otherwise influence the behavior of the identified function.
   - These could `if statements`, `for loops`, or other control structures that guide the flow of the program.
   - Pay close attention to statements that interact with the variables or constants identified in the functions.
   - Provide snippets of code that could be relevant to the fix. Dont hesistate to provide complete code snippets if you think they are relevant.
   - You are free to directly put the code snippets from the file segment that you think are relevant.
   - Collect as many snippets as you think are relevant. The life of humanity depends on this fix, so be sure that the fix is correct and for that you need to gather all the relavent information.
   - You can also focus on statements that call functions that are mentioned in the function ( that was provided to you and where the fix needs to be made ), its ok if they are called with differnt arguments, they can still be useful. For example, if the range has a call to kfree with some arguments and the file segment has a call to kfree with different arguments, that is still useful.
   - Provide as much context as possible about statements as possible. Because information in isolation is not so useful at all. 

3. **Function Signatures and Calls:**
   - Note any function signatures, declarations, or invocations that could provide context or guidance for the fix.

4. **Additional Context:**
   - This is the largest section that you put here, make sure to provide as much context as possible.
   - You can even put small blocks of code here that could be helpful later in the stage when we are making code edits.
   - Gather other contextual details, such as macros, preprocessor directives, type definitions, or patterns, that could help identify expected access patterns, logic, or return values.
   - But whatever informatoin is gathered, please also provide as much context to it as possible. You are free to copy the code around or related to this information.

### **Output Format:**

- All findings must be included between `<memory>` and `</memory>` tags.
- Organize the output for clarity using the following structure given below, this is just a template, you can add anything to this that might be useful

OUTPUT FORMAT: ( the output SHOULD be between <memory> tags )

<memory>
Variables/Constants:
[List]

Related Statements:
[Code snippets with explanation; provide as much context as possible; put entire blocks of code such as snetire if loops / whilte loops etc..]

Function Signatures/Calls:
[List]

Additional Context:
[Observations, access patterns, hints for constants or logic]
</memory>


Make sure to extract and include details that are directly or indirectly relevant to the identified function, even if the connection is not immediately obvious. Focus on identifying patterns, access logic, or hints that can guide the fix and is related to the function that is identified where the fix needs to be made

FILE SEGMENT:
```
{file_segment}
```

You are now provided with a segment of the file *outside* the edit function. Your task is to analyze this file segment and extract any information that might assist in making the fix. The output of your analysis should be enclosed within `<memory>` tags.
Remember that the life of humanity depends on this fix, so be sure that the fix is correct and for that you need to gather all the relavent information.

Often, the pattern for the fix or critical hints for resolving the issue are present elsewhere in the file. These can include guidance on how structures are accessed, which constants need to be returned, or examples of related logic. Your role is to identify such patterns or hints, along with any other relevant details.

Specifically, you should identify and note:

1. **Variables, Definition and Constants:**
   - Document variables or constants from the provided segment that might relate to the problematic function or provide insight into expected behavior.
   - Small definitions of strcutures, macros, or other definitions that might be useful.

2. **Related Statements:**
   - Highlight statements that use related variables, manipulate similar structures, or otherwise influence the behavior of the identified function.
   - These could be `if statements`, `for loops`, or other control structures that guide the flow of the program.
   - Pay close attention to statements that interact with the variables or constants identified in the functions.
   - Provide snippets of code that could be relevant to the fix. Dont hesistate to provide complete code snippets if you think they are relevant.
   - You are free to directly put the code snippets from the file segment that you think are relevant.
   - Collect as many snippets as you think are relevant. The life of humanity depends on this fix, so be sure that the fix is correct and for that you need to gather all the relavent information.
   - You can also focus on statements that call functions that are mentioned in the function ( that was provided to you and where the fix needs to be made ), its ok if they are called with differnt arguments, they can still be useful. For example, if the function has a call to kfree with some arguments and the file segment has a call to kfree with different arguments, that is still useful.
   - Provide as much context as possible about statements as possible. Because information in isolation is not so useful at all. 

3. **Function Signatures and Calls:**
   - Note any function signatures, declarations, or invocations that could provide context or guidance for the fix.

4. **Additional Context:**
   - This is the largest section that you put here, make sure to provide as much context as possible.
   - You can even put small blocks of code here that could be helpful later in the stage when we are making code edits.
   - Gather other contextual details, such as macros, preprocessor directives, type definitions, or patterns, that could help identify expected access patterns, logic, or return values.
   - But whatever informatoin is gathered, please also provide as much context to it as possible. You are free to copy the code around or related to this information.

### **Output Format:**

- All findings must be included between `<memory>` and `</memory>` tags.
- Organize the output for clarity using the following structure given below, this is just a template, you can add anything to this that might be useful

OUTPUT FORMAT: ( the output SHOULD be between <memory> tags )

<memory>
Variables/Constants:
[List]

Related Statements:
[Code snippets with explanation; provide as much context as possible; put entire blocks of code such as snetire if loops / whilte loops etc..]

Function Signatures/Calls:
[List]

Additional Context:
[Observations, access patterns, hints for constants or logic]
</memory>


Make sure to extract and include details that are directly or indirectly relevant to the identified function, even if the connection is not immediately obvious. Focus on identifying patterns, access logic, or hints that can guide the fix and is related to the functions that are identified where the fix needs to be made

"""


GET_FILE_CONTEXT_SYMBOLS_PROMPT = """

You are a Linux kernel developer tasked with fixing a crash in the Linux kernel.

Here are the details of the bug
TITLE:
{title}

CRASH REPORT:
{crash_report}


We have identified a suspicious function `{function_name} in the file `{function_file}` that might be causing the crash or very likely related to a function that is causing the crash:

{function_name}

This is a part of the file `{function_file}`:
{file_contents_truncated}

Functions that are present in the file provided above are:
FUNCTIONS_LIST:
{functions_string}


# Task
Your task is to identify functions from the part of the file `{function_file}` that is provided.
Follow these rules:
1. Identify those functions that very likely related(logically related) to function {function_name}
2. Identify those functions that would help me in understanding the crash, so any function that is related to the crash symptoms or the function `{function_name}` would be useful.
3. You can provide upto a maximum of 3 functions from the part of the file that is provided to you.
4. Dont provide functions that are not related to the crash or the function `{function_name}`.
5. Provide only functions that are present in the part of the file that is provided to you ( use FUNCTIONS_LIST section as a reference )
6. Rank the functions in the order of their relevance to the function `{function_name}` and the crash.
7. Be critical in thinking which functions are related to the crash and which are not.
8. Please follow the output format given below when providing the functions.

# Output format:

1. 
<function>
The name of the function. Give only one function name : io_ring_ctx_free
</function>

<reasoning>
[The reasoning behind why you think this function is the correct according to the rules given above]
</reasoning>


2.
<function>
function name2
</function>

<reasoning>
[some reasoning]
</reasoning>


3.
<function>
function name3
</function>

<reasoning>
[some reasoning]
</reasoning>


...

n.
<function>
function_nameN
</function>

<reasoning>
[some reasoning]
</reasoning>


"""