"""Utilities for generation of latex."""
import re
from typing import List, Optional, Sequence


def escape(s: str) -> str:
    # Escape characters with special meaning in LaTeX.
    s = s.replace('{', R'TEMPBACKSLASHFNDSSKFNSDKNG{')
    s = s.replace('}', R'TEMPBACKSLASHFNDSSKFNSDKNG}')

    s = s.replace('\\', R'\textbackslash{}')
    s = s.replace('%', R'\%{}')
    s = s.replace('$', R'\${}')
    s = s.replace('_', R'\_{}')
    s = s.replace('^', R'\^{}')
    s = s.replace('#', R'\#{}')

    # Annoying unicode stuff.
    s = s.replace('“', R'"')
    s = s.replace('’', R"'")
    s = s.replace('–', R"-")

    # Finish up doing this hack.
    s = s.replace('TEMPBACKSLASHFNDSSKFNSDKNG', '\\')

    return s


def remove_newlines(s: str) -> str:
    return s.replace('\n', ' ')


def rpad_curly(s: str, length: int, s_length: Optional[int] = None):
    # Does not take into account characters in the PDF that
    # are written with multiple characters in the LaTeX (e.g.
    # escape sequences, curly brackets). Use s_length to handle this.
    len_s = s_length if s_length is not None else len(s)
    n_to_add = max(0, length - len_s)
    return s + (n_to_add * ' {}')


def rpad_curly_to_max_length(ss: Sequence[str], additional_padding: int = 0) -> List[str]:
    # Does not take into account characters in the PDF that
    # are written with multiple characters in the LaTeX (e.g.
    # escape sequences, curly brackets).
    if not len(ss):
        return []
    max_length = max(len(s) for s in ss) + additional_padding
    return [rpad_curly(s, max_length) for s in ss]
