2013-12-22 18:55:48 +01:00
#!/usr/bin/python
import monkDebug as debug
2013-12-26 21:17:20 +01:00
import monkModule as module
2013-12-22 18:55:48 +01:00
accessList = [ ' private ' , ' protected ' , ' public ' ]
def debug_space ( level ) :
ret = " "
for iii in range ( 0 , level ) :
ret + = " "
return ret
genericUID = 0
class Node ( ) :
def __init__ ( self , type , name = " " , file = " " , lineNumber = 0 , documentation = [ ] ) :
global genericUID
genericUID + = 1
self . uid = genericUID
2013-12-27 21:35:30 +01:00
self . documenatationCode = [ ]
2013-12-22 18:55:48 +01:00
self . nodeType = type
self . name = name
self . doc = None
self . fileName = file
self . lineNumber = lineNumber
self . subList = None
self . access = None
2013-12-25 23:56:09 +01:00
# namespace elements : (set when all element are parsed ...
self . namespace = [ ]
2013-12-26 07:49:52 +01:00
self . moduleLink = None # this is a link on the main application node or library node (usefull to get the website ...)
2013-12-27 21:35:30 +01:00
self . hiddenRequest = False # @not-in-doc
self . previousRequest = False # @previous
self . add_doc ( documentation )
2013-12-22 18:55:48 +01:00
def to_str ( self ) :
return " "
def str ( self ) :
return self . to_str ( )
def get_node_type ( self ) :
return self . nodeType
def get_name ( self ) :
return self . name
2013-12-27 21:35:30 +01:00
def add_doc ( self , doc ) :
for element in doc :
self . documenatationCode . append ( element )
if element . find ( " @not-in-doc " ) != - 1 :
self . hiddenRequest = True
if element . find ( " @previous " ) != - 1 :
self . previousRequest = True
def get_request_hidden ( self ) :
return self . hiddenRequest
def get_request_in_previous ( self ) :
return self . previousRequest
2013-12-26 07:49:52 +01:00
def get_displayable_name ( self ) :
ret = " "
for namespace in self . namespace :
ret + = namespace + " :: "
ret + = self . name
return ret
2013-12-22 18:55:48 +01:00
def get_uid ( self ) :
return self . uid
def get_doc ( self ) :
#debug.info(str(self.doc))
2013-12-26 21:17:20 +01:00
if len ( self . documenatationCode ) > 0 :
ret = " "
isFirst = True
for req in self . documenatationCode :
if isFirst == False :
ret + = ' \n '
isFirst = False
ret + = req
return ret
2013-12-27 21:35:30 +01:00
if self . nodeType not in [ ' methode ' ] :
return " "
2013-12-26 21:17:20 +01:00
#try to get previous element :
if len ( self . namespace ) == 0 :
2013-12-22 18:55:48 +01:00
return " "
2013-12-26 21:17:20 +01:00
parent = " "
2013-12-22 18:55:48 +01:00
isFirst = True
2013-12-26 21:17:20 +01:00
for namesapace in self . namespace :
2013-12-22 18:55:48 +01:00
if isFirst == False :
2013-12-26 21:17:20 +01:00
parent + = " :: "
2013-12-22 18:55:48 +01:00
isFirst = False
2013-12-26 21:17:20 +01:00
parent + = namesapace
element = module . get_element_with_name ( parent )
if element == None :
return " "
if element . get_node_type ( ) != ' class ' :
return " "
parents = element . get_parents ( )
if len ( parents ) == 0 :
return " "
for myParent in reversed ( parents ) :
element = module . get_element_with_name ( myParent [ ' class ' ] )
if element == None :
continue
heveMethode , pointerMethode = element . have_methode ( self . name )
if heveMethode == False :
continue
if len ( pointerMethode . documenatationCode ) != 0 :
return pointerMethode . get_doc ( )
return " "
def get_lib_name ( self ) :
if self . moduleLink == None :
return None
return self . moduleLink . get_base_doc_node ( ) . get_name ( )
2013-12-22 18:55:48 +01:00
def debug_display ( self , level = 0 , access = None ) :
if access == ' private ' :
debug . info ( debug_space ( level ) + " - " + self . nodeType + " => " + self . name )
elif access == ' protected ' :
debug . info ( debug_space ( level ) + " # " + self . nodeType + " => " + self . name )
elif access == ' public ' :
debug . info ( debug_space ( level ) + " + " + self . nodeType + " => " + self . name )
else :
debug . info ( debug_space ( level ) + self . nodeType + " => " + self . name )
if self . subList != None :
for element in self . subList :
if ' access ' in element . keys ( ) :
element [ ' node ' ] . debug_display ( level + 1 , element [ ' access ' ] )
else :
element [ ' node ' ] . debug_display ( level + 1 )
def set_access ( self , access ) :
if access not in accessList :
debug . warning ( " This is not a valid access : ' " + access + " ' : availlable : " + str ( accessList ) )
return
if self . access == None :
debug . error ( " This Node does not support acces configuration... " )
return
self . access = access
def get_access ( self ) :
return self . access
def append ( self , newSubElement ) :
# just add it in a sub List :
if self . subList == None :
debug . error ( " can not add a ' " + newSubElement . nodeType + " ' at this ' " + self . nodeType + " ' " )
return
if newSubElement . get_node_type ( ) != ' namespace ' :
if self . access == None :
self . subList . append ( { ' node ' : newSubElement } )
else :
self . subList . append ( { ' access ' : self . access , ' node ' : newSubElement } )
return
# check if the element already exist
for element in self . subList :
if element [ ' node ' ] . get_node_type ( ) == ' namespace ' :
if element [ ' node ' ] . get_name ( ) == newSubElement . get_name ( ) :
debug . verbose ( " fusionate with previous declaration " )
element [ ' node ' ] . fusion ( newSubElement )
return
# normal case adding :
if self . access == None :
self . subList . append ( { ' node ' : newSubElement } )
else :
self . subList . append ( { ' access ' : self . access , ' node ' : newSubElement } )
##
## @ brief only for namespace :
##
##
def fusion ( self , addedElement ) :
for element in addedElement . subList :
self . append ( element [ ' node ' ] )
##
## @brief Get the list of all specify type
## @param[in] type Type requested ['namespace', 'class', 'struct', 'methode', 'enum', 'define', 'union', 'variable', 'constructor', 'destructor'] (can be a list)
## @param[in] sorted Request to sort the return list.
## @return The requested list or []
##
def get_all_sub_type ( self , type = ' all ' , sorted = False ) :
if type == ' all ' :
return self . subList
if isinstance ( type , list ) == False :
type = [ type ]
if self . subList == None :
return [ ]
ret = [ ]
for element in self . subList :
if element [ ' node ' ] . get_node_type ( ) in type :
ret . append ( element )
if sorted == True :
# TODO : Sorted the list ...
pass
return ret
2013-12-25 23:56:09 +01:00
2013-12-26 07:49:52 +01:00
def get_doc_website_page ( self ) :
if self . moduleLink == None :
return " "
ret = self . moduleLink . get_website ( )
2013-12-26 21:17:20 +01:00
if ret [ - 1 ] != ' / ' :
ret + = ' / '
2013-12-26 07:49:52 +01:00
ret + = self . get_node_type ( )
ret + = " _ "
for name in self . namespace :
ret + = name + " __ "
ret + = self . name
ret + = ' .html '
return ret
def get_doc_website_page_local ( self ) :
ret = self . get_node_type ( )
ret + = " _ "
for name in self . namespace :
ret + = name + " __ "
ret + = self . name
ret + = ' .html '
return ret
def set_module_link ( self , module ) :
self . moduleLink = module
# set for all sub elements ...
if self . subList == None :
return
if self . nodeType in [ ' class ' , ' namespace ' , ' struct ' ] :
for element in self . subList :
element [ ' node ' ] . set_module_link ( module )
elif self . nodeType in [ ' library ' , ' application ' ] :
for element in self . subList :
element [ ' node ' ] . set_module_link ( module )
2013-12-25 23:56:09 +01:00
def set_namespace ( self , hierarchy = [ ] ) :
2013-12-26 07:49:52 +01:00
#debug.info('set namespace : ' + self.name + ' : ' + str(hierarchy))
2013-12-25 23:56:09 +01:00
# store namespaces:
2013-12-26 07:49:52 +01:00
for tmpName in hierarchy :
self . namespace . append ( tmpName )
2013-12-25 23:56:09 +01:00
# set for all sub elements ...
if self . subList == None :
return
if self . nodeType in [ ' class ' , ' namespace ' , ' struct ' ] :
for element in self . subList :
2013-12-26 07:49:52 +01:00
hierarchy . append ( self . name )
2013-12-25 23:56:09 +01:00
element [ ' node ' ] . set_namespace ( hierarchy )
2013-12-26 07:49:52 +01:00
#debug.info(" ==> " + str(element['node'].get_namespace()))
2013-12-25 23:56:09 +01:00
hierarchy . pop ( )
elif self . nodeType in [ ' library ' , ' application ' ] :
for element in self . subList :
element [ ' node ' ] . set_namespace ( )
2013-12-26 07:49:52 +01:00
#debug.info(" ==> " + str(element['node'].get_namespace()))
2013-12-25 23:56:09 +01:00
def get_namespace ( self ) :
return self . namespace
2013-12-26 07:49:52 +01:00
def complete_display ( self ) :
debug . info ( str ( self . namespace ) + ' : ' + self . name )
if self . subList == None :
return
for element in self . subList :
element [ ' node ' ] . complete_display ( )
2013-12-25 23:56:09 +01:00
def find ( self , list ) :
2013-12-26 07:49:52 +01:00
debug . verbose ( " find : " + str ( list ) + " in " + self . nodeType + " ( " + self . name + " ) " )
2013-12-25 23:56:09 +01:00
if len ( list ) == 0 :
return None
if self . nodeType in [ ' library ' , ' application ' ] :
if self . subList == None :
return None
for element in self . subList :
ret = element [ ' node ' ] . find ( list )
if ret != None :
return ret
return None
if list [ 0 ] != self . name :
return None
tmpList = list [ 1 : ]
2013-12-26 07:49:52 +01:00
if len ( tmpList ) == 0 :
return self
elif self . nodeType not in [ ' class ' , ' namespace ' , ' struct ' ] :
# have other sub element and other elemetn than upper can have sub element ...
return None
2013-12-25 23:56:09 +01:00
if self . subList == None :
return None
for element in self . subList :
ret = element [ ' node ' ] . find ( tmpList )
if ret != None :
return ret
return None
2013-12-26 21:17:20 +01:00
def get_whith_specific_parrent ( self , parrentName ) :
ret = [ ]
# set for all sub elements ...
if self . subList != None :
for element in self . subList :
tmpRet = element [ ' node ' ] . get_whith_specific_parrent ( parrentName )
if len ( tmpRet ) != 0 :
for tmp in tmpRet :
ret . append ( tmp )
return ret
def have_methode ( self , methodeName ) :
if self . subList != None :
for element in self . subList :
if element [ ' node ' ] . get_node_type ( ) != ' methode ' :
continue
if element [ ' access ' ] == " private " :
continue
if element [ ' node ' ] . get_virtual ( ) == False :
continue
if element [ ' node ' ] . get_name ( ) == methodeName :
return [ True , element [ ' node ' ] ]
return [ False , None ]
2013-12-22 18:55:48 +01:00
class MainNode ( Node ) :
def __init__ ( self , type = " library " , name = " " ) :
Node . __init__ ( self , type , name )
2013-12-26 21:17:20 +01:00
self . subList = [ ]
def get_doc_website_page_relative ( base , dest ) :
realBase = " "
tmpBase = " "
lastFolder = " "
for element in base :
tmpBase + = element
if element == ' / ' :
realBase + = tmpBase
lastFolder = tmpBase
tmpBase = " "
if dest [ : len ( realBase ) ] == realBase :
return dest [ len ( realBase ) : ]
#debug.info(dest[:len(realBase)-len(lastFolder)] + "==" + realBase[:-len(lastFolder)])
if dest [ : len ( realBase ) - len ( lastFolder ) ] == realBase [ : - len ( lastFolder ) ] :
return ' ../ ' + dest [ len ( realBase ) - len ( lastFolder ) : ]
return dest