VERSION 1.0 CLASS BEGIN MultiUse = -1 'True Persistable = 0 'NotPersistable DataBindingBehavior = 0 'vbNone DataSourceBehavior = 0 'vbNone MTSTransactionMode = 0 'NotAnMTSObject END Attribute VB_Name = "HHT" Attribute VB_GlobalNameSpace = False Attribute VB_Creatable = False Attribute VB_PredeclaredId = False Attribute VB_Exposed = True Attribute VB_Ext_KEY = "SavedWithClassBuilder6" ,"Yes" Attribute VB_Ext_KEY = "Top_Level" ,"No" Option Explicit Private WithEvents p_clsTaxonomy As Taxonomy Attribute p_clsTaxonomy.VB_VarHelpID = -1 Private p_clsKeywords As Keywords Private p_clsStopSigns As StopSigns Private p_clsStopWords As StopWords Private Const LCID_ENGLISH As Long = 1033 Private Const PACKAGE_DESCRIPTION As String = "package_description.xml" Private Const CHQ_C As String = ".chq" Private Const CHM_C As String = ".chm" Private Const HHK_C As String = ".hhk" Private Const TAXONOMY_HHT_C As String = "Taxonomy.hht" Private Const STOP_SIGNS_HHT_C As String = "StopSigns.hht" Private Const STOP_WORDS_HHT_C As String = "StopWords.hht" Private Const SYN_TABLE_HHT_C As String = "SynTable.hht" Private Const SCOPE_DEFINITION_HHT_C As String = "ScopeDefinition.hht" Private Const NO_LOC_HHT_C As String = "NoLoc.hht" Private Const OPERATORS_HHT_C As String = "OperatorEntries.hht" Private Const START_TAG_C As String = "" Private Const END_TAG_C As String = "" Private Const SCOPE_DEFINITION_NODE_C As String = "A/SCOPE_DEFINITION" Public Event ReportStatus(ByVal strStatus As String, ByRef blnCancel As Boolean) Private Sub Class_Initialize() Set p_clsTaxonomy = New Taxonomy Set p_clsKeywords = New Keywords Set p_clsStopSigns = New StopSigns Set p_clsStopWords = New StopWords End Sub Private Sub Class_Terminate() Set p_clsTaxonomy = Nothing Set p_clsKeywords = Nothing Set p_clsStopSigns = Nothing Set p_clsStopWords = Nothing End Sub Public Sub GenerateCAB( _ ByVal i_strFileName As String, _ ByVal i_intSKU As Long, _ Optional ByVal i_strLang As String = "ALL" _ ) Dim FSO As Scripting.FileSystemObject Dim WS As IWshShell Dim TSPackage As Scripting.TextStream Dim strTempDir As String Dim strPackage As String Dim strCmd As String Dim enumSKU As SKU_E Set FSO = New Scripting.FileSystemObject Set WS = CreateObject("Wscript.Shell") strTempDir = Environ$("TEMP") & "\__HSCCAB" If (FSO.FolderExists(strTempDir)) Then FSO.DeleteFolder strTempDir, Force:=True End If FSO.CreateFolder strTempDir strPackage = strTempDir & "\" & PACKAGE_DESCRIPTION Set TSPackage = FSO.CreateTextFile(strPackage, Overwrite:=True, Unicode:=True) enumSKU = i_intSKU p_GeneratePackageDescription TSPackage, enumSKU, i_strLang Set TSPackage = Nothing ' Required for cabarc to work GenerateHHT strTempDir, i_intSKU p_CopyFiles FSO, g_clsParameters.FilesToInclude(enumSKU), strTempDir & "\" p_RaiseEventAndLookForCancel "CAB'ing the files." strCmd = "cabarc -r -s 6144 n """ & i_strFileName & """ " & strTempDir & "\*" WS.Run strCmd, , True End Sub Public Sub GenerateHHT( _ ByVal i_strDirName As String, _ ByVal i_intSKU As Long _ ) Dim FSO As Scripting.FileSystemObject Dim TS As Scripting.TextStream Dim colKeywords As Collection Dim intAG As Long Dim enumSKU As SKU_E Dim DOMNode As MSXML2.IXMLDOMNode Dim DOMNodeEntries As MSXML2.IXMLDOMNode Dim DOMNodeRoot As MSXML2.IXMLDOMNode Dim strFileName As String Dim blnOutputOperators As Boolean strFileName = i_strDirName & "\" & TAXONOMY_HHT_C Set FSO = New Scripting.FileSystemObject Set TS = FSO.CreateTextFile(strFileName, Unicode:=True) Set colKeywords = New Collection enumSKU = i_intSKU p_OutputHHTProlog TS, enumSKU intAG = g_clsParameters.AuthoringGroup If (intAG > AG_CORE_MAX_C) Then Set DOMNode = GenerateHHTForAuthoringGroup(i_intSKU) Set DOMNode = XMLFindFirstNode(DOMNode, HHT_TAXONOMY_ENTRIES_C) p_RemoveUnnecessaryAttributes DOMNode TS.WriteLine DOMNode.XML Else p_clsKeywords.GetAllKeywordsColl colKeywords Set DOMNode = p_clsTaxonomy.GetTaxonomyInXml Set DOMNodeEntries = XMLFindFirstNode(DOMNode, HHT_TAXONOMY_ENTRIES_C) Set DOMNodeRoot = XMLFindFirstNode(DOMNodeEntries, HHT_TAXONOMY_ENTRY_C) p_clsTaxonomy.TransformHHTTov10 DOMNodeRoot, colKeywords, "", _ ALL_SKUS_C, DOMNodeEntries, i_intSKU, False p_RemoveUnnecessaryAttributes DOMNodeEntries TS.WriteLine DOMNodeEntries.XML End If If (intAG <= AG_CORE_MAX_C) Then If (i_intSKU <> SKU_WINDOWS_MILLENNIUM_E) Then p_OutputStopSigns i_strDirName & "\" & STOP_SIGNS_HHT_C p_OutputStopWords i_strDirName & "\" & STOP_WORDS_HHT_C p_OutputSynonyms i_strDirName & "\" & SYN_TABLE_HHT_C p_OutputOperators i_strDirName & "\" & OPERATORS_HHT_C End If blnOutputOperators = True End If p_PrintWithIndentation TS, 0, "" p_OutputScopeAndNoLoc i_strDirName, enumSKU, blnOutputOperators End Sub Private Sub p_RemoveUnnecessaryAttributes( _ ByRef u_DOMNode As MSXML2.IXMLDOMNode _ ) Dim Element As MSXML2.IXMLDOMElement For Each Element In u_DOMNode.childNodes If (XMLGetAttribute(Element, HHT_URI_C) = "") Then Element.removeAttribute HHT_URI_C End If If (XMLGetAttribute(Element, HHT_ICONURI_C) = "") Then Element.removeAttribute HHT_ICONURI_C End If If (XMLGetAttribute(Element, HHT_DESCRIPTION_C) = "") Then Element.removeAttribute HHT_DESCRIPTION_C End If If (XMLGetAttribute(Element, HHT_VISIBLE_C) = "True") Then Element.removeAttribute HHT_VISIBLE_C End If If (XMLGetAttribute(Element, HHT_SUBSITE_C) = "False") Then Element.removeAttribute HHT_SUBSITE_C End If If (XMLGetAttribute(Element, HHT_NAVIGATIONMODEL_C) = "Default") Then Element.removeAttribute HHT_NAVIGATIONMODEL_C End If Next End Sub Private Function p_GetAllowedSKUs( _ ByRef i_DOMNode As MSXML2.IXMLDOMNode _ ) As SKU_E Dim DOMNode As MSXML2.IXMLDOMNode Dim DOMNodeParent As MSXML2.IXMLDOMNode Dim intTID As Long Dim enumParentAllowedSKUs As SKU_E Dim enumParentSKUs As SKU_E p_GetAllowedSKUs = ALL_SKUS_C If (i_DOMNode.nodeName <> HHT_TAXONOMY_ENTRY_C) Then Exit Function End If intTID = XMLGetAttribute(i_DOMNode, HHT_tid_C) If (intTID = ROOT_TID_C) Then Exit Function End If Set DOMNodeParent = i_DOMNode.parentNode If (DOMNodeParent Is Nothing) Then Exit Function End If enumParentAllowedSKUs = p_GetAllowedSKUs(DOMNodeParent) enumParentSKUs = XMLGetAttribute(DOMNodeParent, HHT_skus_C) p_GetAllowedSKUs = enumParentAllowedSKUs And enumParentSKUs End Function Private Sub p_AddDBParameters( _ ByRef i_DOMDoc As MSXML2.DOMDocument, _ ByRef u_DOMNode As MSXML2.IXMLDOMNode _ ) Dim Element As MSXML2.IXMLDOMElement Dim DOMNodeParameters As MSXML2.IXMLDOMNode Dim DOMNodeParameter As MSXML2.IXMLDOMNode Dim arrNames() As String Dim strName As String Dim vntValue As Variant Dim intIndex As Long Dim i As Long Set Element = i_DOMDoc.createElement(HHT_dbparameters_C) Set DOMNodeParameters = u_DOMNode.appendChild(Element) ReDim arrNames(85) arrNames(i) = MINIMUM_KEYWORD_VALIDATION_C: i = i + 1 arrNames(i) = VENDOR_STRING_C: i = i + 1 arrNames(i) = BROKEN_LINK_WORKING_DIR_C & Hex(SKU_STANDARD_E): i = i + 1 arrNames(i) = BROKEN_LINK_WORKING_DIR_C & Hex(SKU_PROFESSIONAL_E): i = i + 1 arrNames(i) = BROKEN_LINK_WORKING_DIR_C & Hex(SKU_SERVER_E): i = i + 1 arrNames(i) = BROKEN_LINK_WORKING_DIR_C & Hex(SKU_ADVANCED_SERVER_E): i = i + 1 arrNames(i) = BROKEN_LINK_WORKING_DIR_C & Hex(SKU_DATA_CENTER_SERVER_E): i = i + 1 arrNames(i) = BROKEN_LINK_WORKING_DIR_C & Hex(SKU_PROFESSIONAL_64_E): i = i + 1 arrNames(i) = BROKEN_LINK_WORKING_DIR_C & Hex(SKU_ADVANCED_SERVER_64_E): i = i + 1 arrNames(i) = BROKEN_LINK_WORKING_DIR_C & Hex(SKU_DATA_CENTER_SERVER_64_E): i = i + 1 arrNames(i) = BROKEN_LINK_WORKING_DIR_C & Hex(SKU_WINDOWS_MILLENNIUM_E): i = i + 1 arrNames(i) = BROKEN_LINK_WORKING_DIR_C & Hex(SKU_DESKTOP_ALL_E): i = i + 1 arrNames(i) = BROKEN_LINK_WORKING_DIR_C & Hex(SKU_SERVER_ALL_E): i = i + 1 arrNames(i) = BROKEN_LINK_WORKING_DIR_C & Hex(SKU_ALL_E): i = i + 1 arrNames(i) = PRODUCT_ID_C & Hex(SKU_STANDARD_E): i = i + 1 arrNames(i) = PRODUCT_ID_C & Hex(SKU_PROFESSIONAL_E): i = i + 1 arrNames(i) = PRODUCT_ID_C & Hex(SKU_SERVER_E): i = i + 1 arrNames(i) = PRODUCT_ID_C & Hex(SKU_ADVANCED_SERVER_E): i = i + 1 arrNames(i) = PRODUCT_ID_C & Hex(SKU_DATA_CENTER_SERVER_E): i = i + 1 arrNames(i) = PRODUCT_ID_C & Hex(SKU_PROFESSIONAL_64_E): i = i + 1 arrNames(i) = PRODUCT_ID_C & Hex(SKU_ADVANCED_SERVER_64_E): i = i + 1 arrNames(i) = PRODUCT_ID_C & Hex(SKU_DATA_CENTER_SERVER_64_E): i = i + 1 arrNames(i) = PRODUCT_ID_C & Hex(SKU_WINDOWS_MILLENNIUM_E): i = i + 1 arrNames(i) = PRODUCT_ID_C & Hex(SKU_DESKTOP_ALL_E): i = i + 1 arrNames(i) = PRODUCT_ID_C & Hex(SKU_SERVER_ALL_E): i = i + 1 arrNames(i) = PRODUCT_ID_C & Hex(SKU_ALL_E): i = i + 1 arrNames(i) = PRODUCT_VERSION_C & Hex(SKU_STANDARD_E): i = i + 1 arrNames(i) = PRODUCT_VERSION_C & Hex(SKU_PROFESSIONAL_E): i = i + 1 arrNames(i) = PRODUCT_VERSION_C & Hex(SKU_SERVER_E): i = i + 1 arrNames(i) = PRODUCT_VERSION_C & Hex(SKU_ADVANCED_SERVER_E): i = i + 1 arrNames(i) = PRODUCT_VERSION_C & Hex(SKU_DATA_CENTER_SERVER_E): i = i + 1 arrNames(i) = PRODUCT_VERSION_C & Hex(SKU_PROFESSIONAL_64_E): i = i + 1 arrNames(i) = PRODUCT_VERSION_C & Hex(SKU_ADVANCED_SERVER_64_E): i = i + 1 arrNames(i) = PRODUCT_VERSION_C & Hex(SKU_DATA_CENTER_SERVER_64_E): i = i + 1 arrNames(i) = PRODUCT_VERSION_C & Hex(SKU_WINDOWS_MILLENNIUM_E): i = i + 1 arrNames(i) = PRODUCT_VERSION_C & Hex(SKU_DESKTOP_ALL_E): i = i + 1 arrNames(i) = PRODUCT_VERSION_C & Hex(SKU_SERVER_ALL_E): i = i + 1 arrNames(i) = PRODUCT_VERSION_C & Hex(SKU_ALL_E): i = i + 1 arrNames(i) = DISPLAY_NAME_C & Hex(SKU_STANDARD_E): i = i + 1 arrNames(i) = DISPLAY_NAME_C & Hex(SKU_PROFESSIONAL_E): i = i + 1 arrNames(i) = DISPLAY_NAME_C & Hex(SKU_SERVER_E): i = i + 1 arrNames(i) = DISPLAY_NAME_C & Hex(SKU_ADVANCED_SERVER_E): i = i + 1 arrNames(i) = DISPLAY_NAME_C & Hex(SKU_DATA_CENTER_SERVER_E): i = i + 1 arrNames(i) = DISPLAY_NAME_C & Hex(SKU_PROFESSIONAL_64_E): i = i + 1 arrNames(i) = DISPLAY_NAME_C & Hex(SKU_ADVANCED_SERVER_64_E): i = i + 1 arrNames(i) = DISPLAY_NAME_C & Hex(SKU_DATA_CENTER_SERVER_64_E): i = i + 1 arrNames(i) = DISPLAY_NAME_C & Hex(SKU_WINDOWS_MILLENNIUM_E): i = i + 1 arrNames(i) = DISPLAY_NAME_C & Hex(SKU_DESKTOP_ALL_E): i = i + 1 arrNames(i) = DISPLAY_NAME_C & Hex(SKU_SERVER_ALL_E): i = i + 1 arrNames(i) = DISPLAY_NAME_C & Hex(SKU_ALL_E): i = i + 1 arrNames(i) = DOM_FRAGMENT_PKG_C & Hex(SKU_STANDARD_E): i = i + 1 arrNames(i) = DOM_FRAGMENT_PKG_C & Hex(SKU_PROFESSIONAL_E): i = i + 1 arrNames(i) = DOM_FRAGMENT_PKG_C & Hex(SKU_SERVER_E): i = i + 1 arrNames(i) = DOM_FRAGMENT_PKG_C & Hex(SKU_ADVANCED_SERVER_E): i = i + 1 arrNames(i) = DOM_FRAGMENT_PKG_C & Hex(SKU_DATA_CENTER_SERVER_E): i = i + 1 arrNames(i) = DOM_FRAGMENT_PKG_C & Hex(SKU_PROFESSIONAL_64_E): i = i + 1 arrNames(i) = DOM_FRAGMENT_PKG_C & Hex(SKU_ADVANCED_SERVER_64_E): i = i + 1 arrNames(i) = DOM_FRAGMENT_PKG_C & Hex(SKU_DATA_CENTER_SERVER_64_E): i = i + 1 arrNames(i) = DOM_FRAGMENT_PKG_C & Hex(SKU_WINDOWS_MILLENNIUM_E): i = i + 1 arrNames(i) = DOM_FRAGMENT_PKG_C & Hex(SKU_DESKTOP_ALL_E): i = i + 1 arrNames(i) = DOM_FRAGMENT_PKG_C & Hex(SKU_SERVER_ALL_E): i = i + 1 arrNames(i) = DOM_FRAGMENT_PKG_C & Hex(SKU_ALL_E): i = i + 1 arrNames(i) = DOM_FRAGMENT_HHT_C & Hex(SKU_STANDARD_E): i = i + 1 arrNames(i) = DOM_FRAGMENT_HHT_C & Hex(SKU_PROFESSIONAL_E): i = i + 1 arrNames(i) = DOM_FRAGMENT_HHT_C & Hex(SKU_SERVER_E): i = i + 1 arrNames(i) = DOM_FRAGMENT_HHT_C & Hex(SKU_ADVANCED_SERVER_E): i = i + 1 arrNames(i) = DOM_FRAGMENT_HHT_C & Hex(SKU_DATA_CENTER_SERVER_E): i = i + 1 arrNames(i) = DOM_FRAGMENT_HHT_C & Hex(SKU_PROFESSIONAL_64_E): i = i + 1 arrNames(i) = DOM_FRAGMENT_HHT_C & Hex(SKU_ADVANCED_SERVER_64_E): i = i + 1 arrNames(i) = DOM_FRAGMENT_HHT_C & Hex(SKU_DATA_CENTER_SERVER_64_E): i = i + 1 arrNames(i) = DOM_FRAGMENT_HHT_C & Hex(SKU_WINDOWS_MILLENNIUM_E): i = i + 1 arrNames(i) = DOM_FRAGMENT_HHT_C & Hex(SKU_DESKTOP_ALL_E): i = i + 1 arrNames(i) = DOM_FRAGMENT_HHT_C & Hex(SKU_SERVER_ALL_E): i = i + 1 arrNames(i) = DOM_FRAGMENT_HHT_C & Hex(SKU_ALL_E): i = i + 1 arrNames(i) = FILES_TO_INCLUDE_C & Hex(SKU_STANDARD_E): i = i + 1 arrNames(i) = FILES_TO_INCLUDE_C & Hex(SKU_PROFESSIONAL_E): i = i + 1 arrNames(i) = FILES_TO_INCLUDE_C & Hex(SKU_SERVER_E): i = i + 1 arrNames(i) = FILES_TO_INCLUDE_C & Hex(SKU_ADVANCED_SERVER_E): i = i + 1 arrNames(i) = FILES_TO_INCLUDE_C & Hex(SKU_DATA_CENTER_SERVER_E): i = i + 1 arrNames(i) = FILES_TO_INCLUDE_C & Hex(SKU_PROFESSIONAL_64_E): i = i + 1 arrNames(i) = FILES_TO_INCLUDE_C & Hex(SKU_ADVANCED_SERVER_64_E): i = i + 1 arrNames(i) = FILES_TO_INCLUDE_C & Hex(SKU_DATA_CENTER_SERVER_64_E): i = i + 1 arrNames(i) = FILES_TO_INCLUDE_C & Hex(SKU_WINDOWS_MILLENNIUM_E): i = i + 1 arrNames(i) = FILES_TO_INCLUDE_C & Hex(SKU_DESKTOP_ALL_E): i = i + 1 arrNames(i) = FILES_TO_INCLUDE_C & Hex(SKU_SERVER_ALL_E): i = i + 1 arrNames(i) = FILES_TO_INCLUDE_C & Hex(SKU_ALL_E): i = i + 1 For intIndex = LBound(arrNames) To UBound(arrNames) strName = arrNames(intIndex) vntValue = g_clsParameters.Value(strName) If (Not IsNull(vntValue)) Then Set Element = i_DOMDoc.createElement(HHT_dbparameter_C) Set DOMNodeParameter = DOMNodeParameters.appendChild(Element) XMLSetAttribute DOMNodeParameter, HHT_name_C, strName XMLSetAttribute DOMNodeParameter, HHT_value_C, XMLEscape(vntValue) End If Next End Sub Private Function p_GetHHTForAuthoringGroup( _ ByRef i_DOMNode As MSXML2.IXMLDOMNode, _ ByRef i_colKeywords As Collection, _ ByVal i_intAuthoringGroup As Long, _ ByVal i_intAllowedSKUs As Long _ ) As MSXML2.IXMLDOMNode Dim DOMDoc As MSXML2.DOMDocument Dim DOMNode As MSXML2.IXMLDOMNode Dim DOMNodeParent As MSXML2.IXMLDOMNode Dim DOMElement As MSXML2.IXMLDOMElement Dim strCategory As String Dim intAllowedSKUs As Long Dim intAuthoringGroup As Long Set DOMDoc = New MSXML2.DOMDocument Set DOMNode = HhtPreamble(DOMDoc, True) XMLCopyDOMTree i_DOMNode, DOMNode p_RaiseEventAndLookForCancel "Saving database parameters..." Set DOMNode = DOMNode.parentNode p_AddDBParameters DOMDoc, DOMNode Set DOMNode = XMLFindFirstNode(DOMNode, HHT_TAXONOMY_ENTRY_C) Set DOMNodeParent = DOMNode.parentNode strCategory = p_clsTaxonomy.GetCategory(i_DOMNode) intAllowedSKUs = p_GetAllowedSKUs(i_DOMNode) p_RaiseEventAndLookForCancel "Flattening HHT..." p_clsTaxonomy.TransformHHTTov10 DOMNode, i_colKeywords, strCategory, _ intAllowedSKUs, DOMNodeParent, i_intAllowedSKUs, True For Each DOMNode In DOMNodeParent.childNodes p_RaiseEventAndLookForCancel "Processing title: " & _ XMLGetAttribute(DOMNode, HHT_TITLE_C) intAuthoringGroup = XMLGetAttribute(DOMNode, HHT_authoringgroup_C) If (intAuthoringGroup <> i_intAuthoringGroup) Then DOMNodeParent.removeChild DOMNode Else Set DOMElement = DOMNode DOMElement.removeAttribute HHT_authoringgroup_C If (i_intAllowedSKUs = SKU_WINDOWS_MILLENNIUM_E) Then DOMElement.removeAttribute HHT_ICONURI_C DOMElement.removeAttribute HHT_VISIBLE_C DOMElement.removeAttribute HHT_INSERTMODE_C DOMElement.removeAttribute HHT_INSERTLOCATION_C DOMElement.removeAttribute HHT_SUBSITE_C DOMElement.removeAttribute HHT_NAVIGATIONMODEL_C End If End If Next Set p_GetHHTForAuthoringGroup = DOMDoc End Function Public Sub ExportHHT( _ ByVal i_strFileName As String, _ Optional ByVal i_intAuthoringGroup As Long = INVALID_ID_C _ ) Dim DOMNode As MSXML2.IXMLDOMNode Dim colKeywords As Collection Dim intAG As Long Set DOMNode = p_clsTaxonomy.GetTaxonomyInXml p_RaiseEventAndLookForCancel "Reading keywords..." Set colKeywords = New Collection p_clsKeywords.GetAllKeywordsColl colKeywords If (i_intAuthoringGroup = INVALID_ID_C) Then intAG = g_clsParameters.AuthoringGroup Else intAG = i_intAuthoringGroup End If Set DOMNode = XMLFindFirstNode(DOMNode, HHT_TAXONOMY_ENTRY_C) Set DOMNode = p_GetHHTForAuthoringGroup(DOMNode, colKeywords, intAG, ALL_SKUS_C) FileWrite i_strFileName, DOMNode.XML, False, True End Sub Public Function GenerateHHTForAuthoringGroup( _ ByVal i_intSKU As Long _ ) As MSXML2.IXMLDOMNode Dim DOMNode As MSXML2.IXMLDOMNode Dim DOMNodeEntries As MSXML2.IXMLDOMNode Dim DOMNodeChild As MSXML2.IXMLDOMNode Dim DOMElement As MSXML2.IXMLDOMElement Dim colKeywords As Collection Dim intAG As Long Set DOMNode = p_clsTaxonomy.GetTaxonomyInXml Set colKeywords = New Collection p_clsKeywords.GetAllKeywordsColl colKeywords intAG = g_clsParameters.AuthoringGroup Set DOMNode = XMLFindFirstNode(DOMNode, HHT_TAXONOMY_ENTRY_C) Set DOMNode = p_GetHHTForAuthoringGroup(DOMNode, colKeywords, intAG, i_intSKU) Set DOMNodeEntries = XMLFindFirstNode(DOMNode, HHT_TAXONOMY_ENTRIES_C) For Each DOMNodeChild In DOMNodeEntries.childNodes Set DOMElement = DOMNodeChild DOMElement.removeAttribute HHT_skus_C Next Set GenerateHHTForAuthoringGroup = DOMNode End Function Private Function p_GetOrphanedNodesTopics( _ ByRef u_DOMNodeMain As MSXML2.IXMLDOMNode, _ ByVal i_intAuthoringGroup As Long _ ) As MSXML2.IXMLDOMNode Dim DOMNode As MSXML2.IXMLDOMNode Dim DOMDoc As MSXML2.DOMDocument Dim DOMNodeNew As MSXML2.IXMLDOMNode Dim strTitle As String Dim blnLeaf As Boolean For Each DOMNode In u_DOMNodeMain.childNodes strTitle = XMLGetAttribute(DOMNode, HHT_TITLE_C) blnLeaf = XMLGetAttribute(DOMNode, HHT_leaf_C) If ((strTitle = NODE_FOR_ORPHANS_C) And (Not blnLeaf)) Then Set p_GetOrphanedNodesTopics = DOMNode Exit Function End If Next Set DOMDoc = u_DOMNodeMain.ownerDocument p_clsTaxonomy.CreateFast NODE_FOR_ORPHANS_C, "", 0, NAVMODEL_DEFAULT_NUM_C, _ "", "", ALL_SKUS_C, False, _ ROOT_TID_C, LOC_INCLUDE_ALL_C, False, False, "", "", "", "", _ DOMDoc, DOMNodeNew, i_intAuthoringGroup u_DOMNodeMain.appendChild DOMNodeNew Set p_GetOrphanedNodesTopics = DOMNodeNew End Function Private Function p_GetCategoryNode( _ ByRef u_DOMNodeMain As MSXML2.IXMLDOMNode, _ ByRef i_strCategory As String, _ ByVal i_enumSKUs As SKU_E, _ ByRef u_DOMNodeOrphans As MSXML2.IXMLDOMNode, _ ByVal i_intAuthoringGroup As Long _ ) As MSXML2.IXMLDOMNode Dim DOMDoc As MSXML2.DOMDocument Dim DOMNodeList As MSXML2.IXMLDOMNodeList Dim DOMNode As MSXML2.IXMLDOMNode Dim DOMNodeNew As MSXML2.IXMLDOMNode Dim intIndex As Long Dim strQuery As String Dim enumSKUs As SKU_E Dim intTIDOrphans As Long strQuery = "descendant::TAXONOMY_ENTRY[" strQuery = strQuery & "attribute::" & HHT_category2_C & "=""" & i_strCategory & """]" Set DOMDoc = u_DOMNodeMain.ownerDocument DOMDoc.setProperty "SelectionLanguage", "XPath" Set DOMNodeList = u_DOMNodeMain.selectNodes(strQuery) For intIndex = 0 To DOMNodeList.length - 1 Set DOMNode = DOMNodeList(intIndex) enumSKUs = XMLGetAttribute(DOMNode, HHT_skus_C) If ((enumSKUs And i_enumSKUs) <> 0) Then Set p_GetCategoryNode = DOMNode Exit Function End If Next If (u_DOMNodeOrphans Is Nothing) Then Set u_DOMNodeOrphans = p_GetOrphanedNodesTopics(u_DOMNodeMain, i_intAuthoringGroup) End If intTIDOrphans = XMLGetAttribute(u_DOMNodeOrphans, HHT_tid_C) p_clsTaxonomy.CreateFast i_strCategory, "", 0, NAVMODEL_DEFAULT_NUM_C, _ "", "", i_enumSKUs, False, _ intTIDOrphans, LOC_INCLUDE_ALL_C, True, False, "", "", "", "", _ DOMDoc, DOMNodeNew, i_intAuthoringGroup XMLSetAttribute DOMNodeNew, HHT_category2_C, i_strCategory u_DOMNodeOrphans.appendChild DOMNodeNew Set p_GetCategoryNode = DOMNodeNew End Function Private Sub p_GetBeforeAndAfterNodes( _ ByRef i_DOMNodeCategory As MSXML2.IXMLDOMNode, _ ByRef i_strInsertMode As String, _ ByRef i_strInsertLocation As String, _ ByRef o_DOMNodeBefore As MSXML2.IXMLDOMNode, _ ByRef o_DOMNodeAfter As MSXML2.IXMLDOMNode _ ) Dim DOMNode As MSXML2.IXMLDOMNode Dim strAttribute As String Dim str As String Select Case i_strInsertMode Case HHTVAL_TOP_C Set o_DOMNodeBefore = Nothing Set o_DOMNodeAfter = i_DOMNodeCategory.firstChild Case HHTVAL_AFTER_NODE_C, HHTVAL_AFTER_TOPIC_C If (i_strInsertMode = HHTVAL_AFTER_NODE_C) Then strAttribute = HHT_ENTRY_C Else strAttribute = HHT_URI_C End If For Each DOMNode In i_DOMNodeCategory.childNodes str = XMLGetAttribute(DOMNode, strAttribute) If (str = i_strInsertLocation) Then Set o_DOMNodeBefore = DOMNode Set o_DOMNodeAfter = DOMNode.nextSibling End If Next Case Else Set o_DOMNodeBefore = Nothing Set o_DOMNodeAfter = Nothing End Select End Sub Private Function p_CreateKeyword( _ ByRef i_strKeyword As String _ ) As Long On Error GoTo LErrorHandler p_CreateKeyword = p_clsKeywords.Create(i_strKeyword) Exit Function LErrorHandler: p_CreateKeyword = INVALID_ID_C End Function Private Function p_GetKID( _ ByRef i_strKeyword As String, _ ByRef u_dictKeywords As Scripting.Dictionary _ ) As String Dim intKID As Long If (u_dictKeywords.Exists(i_strKeyword)) Then p_GetKID = u_dictKeywords(i_strKeyword) Else intKID = p_CreateKeyword(i_strKeyword) If (intKID <> INVALID_ID_C) Then u_dictKeywords.Add i_strKeyword, intKID p_GetKID = intKID End If End If End Function Private Function p_GetKeywords( _ ByRef i_DOMNodeHHT As MSXML2.IXMLDOMNode, _ ByRef u_dictKeywords As Scripting.Dictionary _ ) As String Dim DOMNode As MSXML2.IXMLDOMNode If (Not i_DOMNodeHHT.firstChild Is Nothing) Then For Each DOMNode In i_DOMNodeHHT.childNodes p_GetKeywords = p_GetKeywords & p_GetKID(DOMNode.Text, u_dictKeywords) & " " Next p_GetKeywords = FormatKeywordsForTaxonomy(p_GetKeywords) End If End Function Private Sub p_CreateTaxonomyEntry( _ ByRef i_DOMNodeHHT As MSXML2.IXMLDOMNode, _ ByRef u_DOMNodeMain As MSXML2.IXMLDOMNode, _ ByRef u_dictKeywords As Scripting.Dictionary, _ ByRef u_DOMNodeOrphans As MSXML2.IXMLDOMNode, _ ByVal i_intAuthoringGroup As Long _ ) Dim strCategory As String Dim enumSKUs As SKU_E Dim DOMNodeCategory As MSXML2.IXMLDOMNode Dim DOMDoc As MSXML2.DOMDocument Dim DOMNodeNew As MSXML2.IXMLDOMNode Dim DOMNodeBefore As MSXML2.IXMLDOMNode Dim DOMNodeAfter As MSXML2.IXMLDOMNode Dim strTitle As String Dim strURI As String Dim strIconURI As String Dim strDescription As String Dim intType As Long Dim intNavModel As Long Dim blnVisible As Boolean Dim blnSubSite As Boolean Dim strEntry As String Dim blnLeaf As Boolean Dim intParentTID As Long Dim strInsertMode As String Dim strInsertLocation As String Dim intTID As Long Dim intRefTID As Long Dim intOrderUnderParent As Long Dim strKeywords As String strCategory = XMLGetAttribute(i_DOMNodeHHT, HHT_CATEGORY_C) enumSKUs = XMLGetAttribute(i_DOMNodeHHT, HHT_skus_C) If (Len(strCategory) = 0) Then Set DOMNodeCategory = u_DOMNodeMain Else Set DOMNodeCategory = p_GetCategoryNode(u_DOMNodeMain, strCategory, _ enumSKUs, u_DOMNodeOrphans, i_intAuthoringGroup) End If strTitle = XMLGetAttribute(i_DOMNodeHHT, HHT_TITLE_C) p_RaiseEventAndLookForCancel "Creating " & strTitle strURI = XMLGetAttribute(i_DOMNodeHHT, HHT_URI_C) strIconURI = XMLGetAttribute(i_DOMNodeHHT, HHT_ICONURI_C) strDescription = XMLGetAttribute(i_DOMNodeHHT, HHT_DESCRIPTION_C) intType = XMLGetAttribute(i_DOMNodeHHT, HHT_TYPE_C) intNavModel = NavModelNumber(XMLGetAttribute(i_DOMNodeHHT, HHT_NAVIGATIONMODEL_C)) blnVisible = XMLGetAttribute(i_DOMNodeHHT, HHT_VISIBLE_C) blnSubSite = XMLGetAttribute(i_DOMNodeHHT, HHT_SUBSITE_C) strEntry = XMLGetAttribute(i_DOMNodeHHT, HHT_ENTRY_C) If (Len(strEntry) = 0) Then blnLeaf = True End If intParentTID = XMLGetAttribute(DOMNodeCategory, HHT_tid_C) Set DOMDoc = u_DOMNodeMain.ownerDocument strKeywords = p_GetKeywords(i_DOMNodeHHT, u_dictKeywords) p_clsTaxonomy.CreateFast strTitle, strDescription, intType, intNavModel, strURI, strIconURI, _ enumSKUs, blnLeaf, intParentTID, LOC_INCLUDE_ALL_C, blnVisible, blnSubSite, _ strKeywords, "", "", strEntry, DOMDoc, DOMNodeNew, i_intAuthoringGroup p_clsTaxonomy.SetCategory2AndEntry DOMNodeNew, strCategory strInsertMode = XMLGetAttribute(i_DOMNodeHHT, HHT_INSERTMODE_C) strInsertLocation = XMLGetAttribute(i_DOMNodeHHT, HHT_INSERTLOCATION_C) p_GetBeforeAndAfterNodes DOMNodeCategory, strInsertMode, strInsertLocation, _ DOMNodeBefore, DOMNodeAfter intTID = XMLGetAttribute(DOMNodeNew, HHT_tid_C) If (Not DOMNodeBefore Is Nothing) Then intRefTID = XMLGetAttribute(DOMNodeBefore, HHT_tid_C) p_clsTaxonomy.Move intTID, intRefTID, False, 0, intOrderUnderParent If (DOMNodeAfter Is Nothing) Then DOMNodeCategory.appendChild DOMNodeNew Else DOMNodeCategory.insertBefore DOMNodeNew, DOMNodeAfter End If ElseIf (Not DOMNodeAfter Is Nothing) Then intRefTID = XMLGetAttribute(DOMNodeAfter, HHT_tid_C) p_clsTaxonomy.Move intTID, intRefTID, True, 0, intOrderUnderParent DOMNodeCategory.insertBefore DOMNodeNew, DOMNodeAfter Else DOMNodeCategory.appendChild DOMNodeNew End If End Sub Private Sub p_RestoreDBParameters( _ ByRef i_DOMNode As MSXML2.IXMLDOMNode _ ) Dim DOMNode As MSXML2.IXMLDOMNode Dim strName As String Dim strValue As String If (i_DOMNode Is Nothing) Then Exit Sub End If For Each DOMNode In i_DOMNode.childNodes strName = XMLGetAttribute(DOMNode, HHT_name_C) strValue = XMLGetAttribute(DOMNode, HHT_value_C) g_clsParameters.Value(strName) = XMLUnEscape(strValue) Next End Sub Public Sub ImportHHT( _ ByVal i_strFileName As String, _ Optional ByVal i_intAuthoringGroup As Long = INVALID_ID_C _ ) Dim DOMDoc As MSXML2.DOMDocument Dim DOMNodeHHT As MSXML2.IXMLDOMNode Dim DOMNodeMain As MSXML2.IXMLDOMNode Dim DOMNodeEntries As MSXML2.IXMLDOMNode Dim DOMNode As MSXML2.IXMLDOMNode Dim dictKeywords As Scripting.Dictionary Dim DOMNodeOrphans As MSXML2.IXMLDOMNode Dim DOMNodeParameters As MSXML2.IXMLDOMNode Set DOMDoc = New MSXML2.DOMDocument DOMDoc.Load i_strFileName Set DOMNodeHHT = DOMDoc Set DOMNodeMain = p_clsTaxonomy.GetTaxonomyInXml Set DOMNodeMain = XMLFindFirstNode(DOMNodeMain, HHT_TAXONOMY_ENTRY_C) Set dictKeywords = New Scripting.Dictionary p_clsKeywords.GetAllKeywordsDict dictKeywords p_clsTaxonomy.SetCategory2AndEntry DOMNodeMain, "" Set DOMNodeEntries = XMLFindFirstNode(DOMNodeHHT, HHT_TAXONOMY_ENTRIES_C) If (DOMNodeEntries Is Nothing) Then Exit Sub End If For Each DOMNode In DOMNodeEntries.childNodes p_CreateTaxonomyEntry DOMNode, DOMNodeMain, dictKeywords, DOMNodeOrphans, _ i_intAuthoringGroup Next p_RaiseEventAndLookForCancel "Restoring database parameters..." Set DOMNodeParameters = XMLFindFirstNode(DOMNodeHHT, HHT_dbparameters_C) p_RestoreDBParameters DOMNodeParameters End Sub Private Sub p_OutputStopSigns( _ ByVal i_strFileName As String _ ) Dim FSO As Scripting.FileSystemObject Dim TS As Scripting.TextStream Dim dictStopSigns As Scripting.Dictionary Dim intSSID As Variant Dim strContext As String Set FSO = New Scripting.FileSystemObject Set TS = FSO.CreateTextFile(i_strFileName, Unicode:=True) Set dictStopSigns = New Scripting.Dictionary p_clsStopSigns.GetAllStopSignsDict dictStopSigns p_PrintWithIndentation TS, 0, "" p_PrintWithIndentation TS, 0, "" p_PrintWithIndentation TS, 1, "" p_RaiseEventAndLookForCancel "Adding new Stop Signs" For Each intSSID In dictStopSigns.Keys If (dictStopSigns(intSSID)(1) = CONTEXT_ANYWHERE_E) Then strContext = HHTVAL_ANYWHERE_C Else strContext = HHTVAL_ENDOFWORD_C End If p_PrintWithIndentation TS, 2, _ "" Next p_PrintWithIndentation TS, 1, "" p_PrintWithIndentation TS, 0, "" End Sub Private Sub p_OutputStopWords( _ ByVal i_strFileName As String _ ) Dim FSO As Scripting.FileSystemObject Dim TS As Scripting.TextStream Dim dictStopWords As Scripting.Dictionary Dim intSWID As Variant Set FSO = New Scripting.FileSystemObject Set TS = FSO.CreateTextFile(i_strFileName, Unicode:=True) Set dictStopWords = New Scripting.Dictionary p_clsStopWords.GetAllStopWordsDict dictStopWords p_PrintWithIndentation TS, 0, "" p_PrintWithIndentation TS, 0, "" p_PrintWithIndentation TS, 1, "" p_RaiseEventAndLookForCancel "Adding new Stop Words" For Each intSWID In dictStopWords.Keys p_PrintWithIndentation TS, 2, _ "" Next p_PrintWithIndentation TS, 1, "" p_PrintWithIndentation TS, 0, "" End Sub Private Sub p_OutputSynonyms( _ ByVal i_strFileName As String _ ) Dim FSO As Scripting.FileSystemObject Dim TS As Scripting.TextStream Dim clsSynonymSets As SynonymSets Dim rs As ADODB.Recordset Dim intLastEID As Long Dim intEID As Long Set FSO = New Scripting.FileSystemObject Set TS = FSO.CreateTextFile(i_strFileName, Unicode:=True) Set clsSynonymSets = New SynonymSets Set rs = New ADODB.Recordset clsSynonymSets.GetSynonymsRs rs p_PrintWithIndentation TS, 0, "" p_PrintWithIndentation TS, 0, "" p_PrintWithIndentation TS, 1, "" Do While (Not rs.EOF) intEID = rs("EID") If (intEID <> intLastEID) Then If (intLastEID <> 0) Then p_PrintWithIndentation TS, 2, "" End If intLastEID = intEID p_PrintWithIndentation TS, 2, "" p_PrintWithIndentation TS, 2, "" & XMLEscape(rs("Name")) & "" ' For LOC only. HSC ignores this. End If p_PrintWithIndentation TS, 3, "" & XMLEscape(rs("Keyword")) & "" rs.MoveNext Loop If (rs.RecordCount <> 0) Then p_PrintWithIndentation TS, 2, "" End If p_PrintWithIndentation TS, 1, "" p_PrintWithIndentation TS, 0, "" End Sub Private Sub p_OutputScopeAndNoLoc( _ ByVal i_strDirName As String, _ ByVal i_enumSKU As SKU_E, _ ByVal i_blnOutputOperators As Boolean _ ) Dim FSO As Scripting.FileSystemObject Dim TS As Scripting.TextStream Dim DOMDoc As MSXML2.DOMDocument Dim DOMNodeScope As MSXML2.IXMLDOMNode Dim DOMNode As MSXML2.IXMLDOMNode Set FSO = New Scripting.FileSystemObject Set DOMDoc = New MSXML2.DOMDocument DOMDoc.loadXML START_TAG_C & g_clsParameters.DomFragmentHHT(i_enumSKU) & END_TAG_C Set DOMNodeScope = DOMDoc.selectSingleNode(SCOPE_DEFINITION_NODE_C) Set TS = FSO.CreateTextFile(i_strDirName & "\" & SCOPE_DEFINITION_HHT_C, Unicode:=True) p_PrintWithIndentation TS, 0, "" p_PrintWithIndentation TS, 0, "" If (Not DOMNodeScope Is Nothing) Then DOMDoc.childNodes(0).removeChild DOMNodeScope TS.WriteLine DOMNodeScope.XML End If p_PrintWithIndentation TS, 0, "" Set TS = FSO.CreateTextFile(i_strDirName & "\" & NO_LOC_HHT_C, Unicode:=True) p_PrintWithIndentation TS, 0, "" p_PrintWithIndentation TS, 0, "" For Each DOMNode In DOMDoc.childNodes(0).childNodes TS.WriteLine DOMNode.XML Next p_PrintWithIndentation TS, 0, "" End Sub Private Sub p_OutputOperators( _ ByVal i_strFileName As String _ ) Dim FSO As Scripting.FileSystemObject Dim TS As Scripting.TextStream Dim arrOpAnd() As String Dim arrOpOr() As String Dim arrOpNot() As String Dim str As Variant Set FSO = New Scripting.FileSystemObject Set TS = FSO.CreateTextFile(i_strFileName, Unicode:=True) p_PrintWithIndentation TS, 0, "" p_PrintWithIndentation TS, 0, "" GetVerbalOperators arrOpAnd, arrOpOr, arrOpNot p_PrintWithIndentation TS, 1, "" For Each str In arrOpAnd p_PrintWithIndentation TS, 2, _ "" Next For Each str In arrOpOr p_PrintWithIndentation TS, 2, _ "" Next For Each str In arrOpNot p_PrintWithIndentation TS, 2, _ "" Next p_PrintWithIndentation TS, 1, "" p_PrintWithIndentation TS, 0, "" End Sub Private Sub p_GeneratePackageDescription( _ ByVal i_TS As Scripting.TextStream, _ ByVal i_enumSKU As SKU_E, _ ByVal i_strLang As String _ ) Dim strProductId As String Dim strVersion As String strProductId = g_clsParameters.ProductId(i_enumSKU) strVersion = g_clsParameters.ProductVersion(i_enumSKU) If ((strProductId = "") Or (strVersion = "")) Then Err.Raise errProductIdOrVersionMissing End If p_RaiseEventAndLookForCancel "Generating " & PACKAGE_DESCRIPTION p_PrintWithIndentation i_TS, 0, "" p_PrintWithIndentation i_TS, 0, "" p_PrintWithIndentation i_TS, 1, "" p_PrintWithIndentation i_TS, 1, "" If (i_enumSKU <> SKU_WINDOWS_MILLENNIUM_E) Then p_PrintWithIndentation i_TS, 1, "" p_PrintWithIndentation i_TS, 1, "" End If p_PrintWithIndentation i_TS, 1, "" If (i_enumSKU <> SKU_WINDOWS_MILLENNIUM_E) Then If (g_clsParameters.AuthoringGroup <= AG_CORE_MAX_C) Then p_PrintWithIndentation i_TS, 2, "" p_PrintWithIndentation i_TS, 2, "" p_PrintWithIndentation i_TS, 2, "" p_PrintWithIndentation i_TS, 2, "" End If End If ' The taxonomy must appear after the syntable p_PrintWithIndentation i_TS, 2, "" If (i_enumSKU <> SKU_WINDOWS_MILLENNIUM_E) Then p_PrintWithIndentation i_TS, 2, "" p_PrintWithIndentation i_TS, 2, "" End If p_PrintWithIndentation i_TS, 1, "" i_TS.WriteLine g_clsParameters.DomFragmentPackageDesc(i_enumSKU) p_PrintWithIndentation i_TS, 0, "" End Sub Private Sub p_OutputHHTProlog( _ ByVal i_TS As Scripting.TextStream, _ ByVal i_enumSKU As SKU_E _ ) Dim strDateTime As String strDateTime = FormatDateTime(Now, vbLongDate) & " " & FormatDateTime(Now, vbLongTime) p_PrintWithIndentation i_TS, 0, "" p_PrintWithIndentation i_TS, 0, "" p_PrintWithIndentation i_TS, 0, "" End Sub Private Sub p_CopyFiles( _ ByVal i_FSO As Scripting.FileSystemObject, _ ByVal i_strFiles As String, _ ByVal i_strDirectory As String _ ) Dim strFiles() As String Dim intIndex As Long strFiles = Split(i_strFiles, vbCrLf) For intIndex = LBound(strFiles) To UBound(strFiles) If (Not i_FSO.FileExists(strFiles(intIndex))) Then WriteLog "File " & strFiles(intIndex) & " does not exist, and couldn't be copied." Else i_FSO.CopyFile strFiles(intIndex), i_strDirectory End If Next End Sub Private Sub p_PrintWithIndentation( _ ByVal i_TS As Scripting.TextStream, _ ByVal i_intNumIndents As Long, _ ByVal i_strText As String _ ) i_TS.Write Space(i_intNumIndents * 4) i_TS.WriteLine i_strText End Sub Private Sub p_RaiseEventAndLookForCancel( _ ByVal strStatus As String _ ) Dim blnCancel As Boolean blnCancel = False RaiseEvent ReportStatus(strStatus, blnCancel) If (blnCancel) Then Err.Raise errCancel End If End Sub Private Sub p_clsTaxonomy_ReportStatus(ByVal strStatus As String, blnCancel As Boolean) p_RaiseEventAndLookForCancel strStatus End Sub