import json
import csv

def convert_jsonl_to_csv(jsonl_path, csv_path, default_role=None, default_weight=None):
    """
    Convert a JSONL file containing persona records to a CSV file.

    Each line in the input JSONL must be a dictionary with at least:
    - "eid": unique identifier for the persona
    - "endow_text": natural-language description of the persona

    Optionally adds "role" and "weight" columns using provided default values.

    Args:
        jsonl_path (str): Path to the input JSONL file.
        csv_path (str): Path to the output CSV file.
        default_role (str or None): Default value to assign to the "role" column.
        default_weight (str, int, float, or None): Default value to assign to the "weight" column.
    """
    with open(jsonl_path, 'r', encoding='utf-8') as infile, open(csv_path, 'w', newline='', encoding='utf-8') as outfile:
        writer = csv.DictWriter(outfile, fieldnames=["eid", "endow_text", "role", "weight"])
        writer.writeheader()
        for line in infile:
            record = json.loads(line)
            record["role"] = default_role
            record["weight"] = default_weight
            writer.writerow(record)