#
# stm32_serialbuffer.py
#
import pioutil
if pioutil.is_pio_build():
    Import("env")

    # Get a build flag's value or None
    def getBuildFlagValue(name):
        for flag in build_flags:
            if isinstance(flag, list) and flag[0] == name:
                return flag[1]

        return None

    # Get an overriding buffer size for RX or TX from the build flags
    def getInternalSize(side):
        return  getBuildFlagValue(f"MF_{side}_BUFFER_SIZE") or \
                getBuildFlagValue(f"SERIAL_{side}_BUFFER_SIZE") or \
                getBuildFlagValue(f"USART_{side}_BUF_SIZE")

    # Get the largest defined buffer size for RX or TX
    def getBufferSize(side, default):
        # Get a build flag value or fall back to the given default
        internal = int(getInternalSize(side) or default)
        flag = side + "_BUFFER_SIZE"
        # Return the largest value
        return max(int(mf[flag]), internal) if flag in mf else internal

    # Add a build flag if it's not already defined
    def tryAddFlag(name, value):
        if getBuildFlagValue(name) is None:
            env.Append(BUILD_FLAGS=[f"-D{name}={value}"])

    # Marlin uses the `RX_BUFFER_SIZE` \ `TX_BUFFER_SIZE` options to
    # configure buffer sizes for receiving \ transmitting serial data.
    # Stm32duino uses another set of defines for the same purpose, so this
    # script gets the values from the configuration and uses them to define
    # `SERIAL_RX_BUFFER_SIZE` and `SERIAL_TX_BUFFER_SIZE` as global build
    # flags so they are available for use by the platform.
    #
    # The script will set the value as the default one (64 bytes)
    # or the user-configured one, whichever is higher.
    #
    # Marlin's default buffer sizes are 128 for RX and 32 for TX.
    # The highest value is taken (128/64).
    #
    # If MF_*_BUFFER_SIZE, SERIAL_*_BUFFER_SIZE, USART_*_BUF_SIZE, are
    # defined, the first of these values will be used as the minimum.
    build_flags = env.ParseFlags(env.get('BUILD_FLAGS'))["CPPDEFINES"]
    mf = env["MARLIN_FEATURES"]

    # Get the largest defined buffer sizes for RX or TX, using defaults for undefined
    rxBuf = getBufferSize("RX", 128)
    txBuf = getBufferSize("TX",  64)

    # Provide serial buffer sizes to the stm32duino platform
    tryAddFlag("SERIAL_RX_BUFFER_SIZE", rxBuf)
    tryAddFlag("SERIAL_TX_BUFFER_SIZE", txBuf)
    tryAddFlag("USART_RX_BUF_SIZE", rxBuf)
    tryAddFlag("USART_TX_BUF_SIZE", txBuf)