from prompta.utils.java_libs import AbstractTTTHypothesis

# from typing import Any, Tuple
# from jpype import JImplements, JOverride, JInt
# from pipelines.prompta.learner.ttt_utils.core.ttt_state import TTTState
# from pipelines.prompta.learner.ttt_utils.core.ttt_transition import TTTTransition
# from prompta.utils.java_libs import Alphabet, Alphabets, DeterministicAutomaton, DefaultVisualizationHelper, FiniteAlphabetAutomaton, FullIntAbstraction, Graph, SupportsGrowingAlphabet, ArrayList


# class TTTEdge:
#     def __init__(self, transition: TTTTransition, target: TTTState):
#         self.transition = transition
#         self.target = target


# @JImplements([Graph])
# class GraphView:

#     def __init__(self, states) -> None:
#         self.states = states

#     @JOverride
#     def getNodes(self):
#         return tuple(self.states)
    
#     @JOverride
#     def getOutgoingEdges(self, node):
#         result = []
#         for trans in node.getTransitions():
#             for target in trans.getDTTarget().subtreeStates():
#                 result.append(TTTEdge(trans, target))
#         return result
    
#     @JOverride
#     def getTarget(self, edge):
#         return edge.target
    
#     @JOverride
#     def getVisualizationHelper(self):
#         @JOverride
#         def getEdgeProperties(src, edge, tgt, properties):
#             properties.put(EdgeAttrs.LABEL, str(edge.transition.getInput()))
#             if edge.transition.isTree():
#                 properties.put(EdgeAttrs.STYLE, EdgeStyles.BOLD)
#             elif edge.transition.getDTTarget().isInner():
#                 properties.put(EdgeAttrs.STYLE, EdgeStyles.DOTTED)
#             return True
#         return DefaultVisualizationHelper(getEdgeProperties)


# @JImplements([DeterministicAutomaton, FiniteAlphabetAutomaton, FullIntAbstraction, SupportsGrowingAlphabet], deferred=True)
# class AbstractTTTHypothesis:

#     def __init__(self, alphabet: Alphabet):
#         self.alphabet = alphabet
#         self.alphabetSize = self.alphabet.size()
#         self.states = ArrayList()
#         self.initialState = None

#     @JOverride
#     def getIinitialState(self) -> TTTState:
#         return self.initialState

#     @JOverride
#     def getTransition(self, stateId: int, symIdx: int):
#         state = self.states.get(stateId)
#         trans = state.getInternalTransition(state, symIdx)
#         return self.mapTransition(trans)
    
#     @JOverride
#     def getTransition(self, state, input):
#         trans = state.getInternalTransition(state, input)
#         return None if trans is None else self.mapTransition(trans)
    
#     def getInternalTransition(self, state, input):
#         if not isinstance(input, int):
#             input = self.alphabet.getSymbolIndex(input)
#         return state.getTransition(input)

#     def mapTransition(self, internal_transition):
#         raise NotImplementedError()
    
#     def initialize(self):
#         assert not self.isInitialized()

#         self.initialState = self.createState(None)
#         return self.initialState

#     def isInitialized(self) -> bool:
#         return self.initialState is not None
    
#     def createState(self, parent: TTTTransition):
#         state = self.newState(self.alphabet.size(), parent, self.states.size())
#         self.states.add(state)
#         if parent is not None:
#             parent.makeTree(state)
#         return state
    
#     def newState(self, alphabetSize: int, parent: TTTTransition, id: int) -> TTTState:
#         raise NotImplementedError()
    
#     @JOverride
#     def getInputAlphabet(self) -> Alphabet:
#         return self.alphabet
    
#     @JOverride
#     def graphView(self):
#         return GraphView(self.states)
    
#     @JOverride
#     def getIntInitialState(self) -> int:
#         return 0
    
#     @JOverride
#     def numInputs(self) -> int:
#         return self.alphabetSize
    
#     @JOverride
#     def getIntSuccessor(self, trans) -> int:
#         return self.getSuccessor(trans).id
    
#     @JOverride
#     def fullIntAbstraction(self, alphabet: Alphabet) -> FullIntAbstraction:
#         if alphabet == self.alphabet:
#             return self
#         return DeterministicAutomaton.super.fullIntAbstraction(alphabet)
    
#     @JOverride
#     def addAlphabetSymbol(self, symbol):
#         growingAlphabet = Alphabets.toGrowingAlphabetOrThrowException(self.alphabet)

#         if not growingAlphabet.containsSymbol(symbol):
#             growingAlphabet.addSymbol(symbol)

#         newAlphabetSize = growingAlphabet.size()

#         if self.alphabetSize < newAlphabetSize:
#             for state in self.getStates():
#                 state.ensureInputCapacity(newAlphabetSize)

#             self.alphabetSize = newAlphabetSize

#     @JOverride
#     def getStates(self) -> Tuple:
#         return tuple(self.states)

#     @JOverride
#     def size(self) -> int:
#         return self.states.size()







