THEO TODMAN’S WEBSITE CODE PAGES



This Page provides a jumping-off point for the VBA Code that generates my Website.

Table of Code Documentation Location 6 (3 items)

CreateAbstractWebPagesCreateModulesWebpageWebrefs_Update.

To access information, click on one of the links in the table above.

Go to top of page




Source Code of: CreateAbstractWebPages
Procedure Type: Public Sub
Module: General_Subroutines
Lines of Code: 462
Go To End of This Procedure

Line-No. / Ref.Code Line
0001Public Sub CreateAbstractWebPages()
0002Dim fsoTextFile As FileSystemObject
0003Dim tsTextFile As TextStream
0004Dim rsTableToRead As Recordset
0005Dim rsTableToRead2 As Recordset
0006Dim rsTableControl As Recordset
0007Dim rsCitings As Recordset
0008Dim rsNote As Recordset
0009Dim strControlQuery As String
0010Dim strLine As String
0011Dim strText As String
0012Dim strComment As String
0013Dim strAbstract As String
0014Dim i As Integer
0015Dim x As Long
0016Dim StartTime As Date
0017Dim RunStartTime As Date
0018Dim Duration As Double
0019Dim Response As String
0020Dim strMessage As String
0021Dim Total_Run As Single
0022Dim Run_Type As String
0023Dim All_Done As Boolean
0024Dim RunDate As Date
0025Dim strAuthor As String
0026Dim NoteID As Integer
0027Dim SubDirectory As String
0028Dim iCount As Long
0029Dim strLine1 As String
0030Dim Link_Count As Integer
0031Dim Link_1 As String
0032Dim Link_2 As String
0033Dim Link_3 As String
0034Dim Link_4 As String
0035Dim Link_4_Saved As String
0036Dim Link_5 As String
0037Dim Link_6 As String
0038Dim Link_Authors As String
0039Dim strTable As String
0040Dim strQuery As String
0041Dim strNote_Date As String
0042Dim sw As StopWatch
0043Dim sw2 As StopWatch
0044'Test_Flag = True
0045If Test_Flag = True Then
0046 Set sw = New StopWatch
0047 Set sw2 = New StopWatch
0048End If
0049iCount = 0
0050Set fsoTextFile = New FileSystemObject
0051NotePaperLinksDB_Open = "Closed"
0052Cross_Reference_Table_Open = False
0053Set rsCross_Reference_Table = Nothing
0054Total_Run = 0
0055If automatic_processing = "Yes" Then
0056 Run_Type = "Regen"
0057 Response = vbYes
0058 GoTo Automatic
0059End If
0060Response = MsgBox("Do you want to regenerate pages for changed Abstracts only?", vbYesNoCancel)
0061If Response = vbYes Then
0062 Response = MsgBox("Do you want to include pages with embedded Notes?", vbYesNo + vbDefaultButton2)
0063 If Response = vbYes Then
0064 Response = MsgBox("Do you want to include pages with embedded Temp Notes only?", vbYesNo + vbDefaultButton1)
0065 If Response = vbYes Then
0066 strControlQuery = "Abstracts_Changed_List_Plus+TempNotes"
0067 Else
0068 strControlQuery = "Abstracts_Changed_List_Plus+Notes"
0069 Response = vbYes
0070 End If
0071 Else
0072 strControlQuery = "Abstracts_Changed_List"
0073 Response = vbYes
0074 End If
0075 Run_Type = "Changed"
0076Else
0077 Run_Type = "Regen"
0078 If Response = vbNo Then
0079 Response = Paper_Abstracts_Selection
0080 If Response = vbYes Then
0081 Run_Type = "Selected"
0082 strControlQuery = "Abstracts_Selected_List"
0083 Else
0084 Response = MsgBox("Do you want to regenerate Abstract pages for Papers with IDs in particular ranges?", vbYesNoCancel)
0085 If Response = vbYes Then
0086 Set rsTableToRead = CurrentDb.OpenRecordset("SELECT * FROM Paper_Abstract_Ranges WHERE [Select?] = True ORDER BY ID_Start;")
0087 If Not rsTableToRead.EOF Then
0088 rsTableToRead.MoveFirst
0089 strMessage = "Run for the following range" & IIf(rsTableToRead.RecordCount > 1, "s", "") & "?" & Chr(10) & Chr(10)
0090 Do While Not rsTableToRead.EOF
0091 strMessage = strMessage & rsTableToRead.Fields(0) & ": " & rsTableToRead.Fields(1) & "-" & rsTableToRead.Fields(2) & ": " & Round(rsTableToRead.Fields(5), 0) & "m (" & Round(rsTableToRead.Fields(4), 0) & ", " & Round((Now() - Round(rsTableToRead.Fields(4))), 0) & "d)" & Chr(10)
0092 Total_Run = Total_Run + Nz(rsTableToRead.Fields(5))
0093 rsTableToRead.MoveNext
0094 Loop
0095 strMessage = strMessage & "Total = " & Round(Total_Run, 0) & "m." & Chr(10) & Chr(10)
0096 Else
0097 DoCmd.OpenTable ("Paper_Abstract_Ranges")
0098 MsgBox ("No Ranges selected. Update the Paper_Abstract_Ranges Table.")
0099 End
0100 End If
0101 Total_Run = 0
0102 Set rsTableToRead = CurrentDb.OpenRecordset("SELECT * FROM Paper_Abstract_Ranges WHERE [Select?] = False ORDER BY ID_Start;")
0103 If Not rsTableToRead.EOF Then
0104 strMessage = strMessage & "Not selected:- " & Chr(10) & Chr(10)
0105 rsTableToRead.MoveFirst
0106 Do While Not rsTableToRead.EOF
0107 strMessage = strMessage & rsTableToRead.Fields(0) & ": " & rsTableToRead.Fields(1) & "-" & rsTableToRead.Fields(2) & ": " & Round(rsTableToRead.Fields(5), 0) & " mins (" & Round(rsTableToRead.Fields(4), 0) & ", " & Round((Now() - Round(rsTableToRead.Fields(4))), 0) & " days)" & Chr(10)
0108 Total_Run = Total_Run + rsTableToRead.Fields(5)
0109 rsTableToRead.MoveNext
0110 Loop
0111 strMessage = strMessage & "Total o/s = " & Round(Total_Run, 0) & "m." & Chr(10) & Chr(10)
0112 End If
0113 Response = MsgBox(strMessage, vbYesNo)
0114 If Response = vbNo Then
0115 DoCmd.OpenTable ("Paper_Abstract_Ranges")
0116 MsgBox ("Update the Paper_Abstract_Ranges Table.")
0117 End
0118 End If
0119 End If
0120 End If
0121 End If
0122End If
0123Automatic:
0124If Response <> vbYes Then
0125 MsgBox ("Try again!")
0126 Exit Sub
0127End If
0128RunStartTime = Now()
0129StartTime = Now()
0130 OK = Convert_Webrefs("Paper", "Full")
0131If Run_Type = "Changed" Or Run_Type = "Selected" Then
0132 Set rsTableToRead = CurrentDb.OpenRecordset(strControlQuery)
0133 If rsTableToRead.EOF Then
0134 MsgBox ("No changed abstracts!")
0135 Exit Sub
0136 End If
0137Else
0138 Set rsTableToRead2 = CurrentDb.OpenRecordset("SELECT * FROM Paper_Abstract_Ranges WHERE [Select?] = True ORDER BY ID_Start;")
0139 If rsTableToRead2.EOF Then
0140 All_Done = True
0141 Else
0142 All_Done = False
0143 rsTableToRead2.MoveFirst
0144 End If
0145End If
0146All_Done = False
0147'Output Abstract Pages
0148Do Until All_Done = True
0149 If Run_Type = "Changed" Or Run_Type = "Selected" Then
0150 All_Done = True
0151 Else
0152 'Generate records list
0153 strControlQuery = "SELECT * FROM Abstracts_List WHERE (ID >= " & rsTableToRead2.Fields(1) & " AND ID <= " & rsTableToRead2.Fields(2) & ") ORDER BY ID;"
0154 Set rsTableToRead = CurrentDb.OpenRecordset(strControlQuery)
0155 If Not rsTableToRead.EOF Then
0156 rsTableToRead.MoveFirst
0157 End If
0158 End If
0159 strControlQuery = "SELECT Website_Control.Line_Value FROM Website_Control WHERE (((Website_Control.Web_Page) = ""Abstract"") And ((Website_Control.Section) = ""Text"")) ORDER BY Website_Control.Line;"
0160 Set rsTableControl = CurrentDb.OpenRecordset(strControlQuery)
0161 If Not rsTableToRead.EOF Then
0162 rsTableToRead.MoveFirst
0163 End If
0164 Do While Not rsTableToRead.EOF
0165 If Test_Flag = True Then
0166 sw.StartTimer
0167 End If
0168 Clear_Colour_Usage
0169 strFolder = TheoWebsiteRoot & "\Abstracts\Abstract_" & Right(Str(Int(rsTableToRead.Fields(0) / 1000) + 1000000), 2) & "\"
0170 strFileName = "Abstract_" & rsTableToRead.Fields(0) & ".htm"
0171 Set tsTextFile = fsoTextFile.CreateTextFile(strFolder & strFileName, True, True)
0172 rsTableControl.MoveFirst
0173 OK = Zap_Cross_References("P", rsTableToRead.Fields(0), 0)
0174 'NameRef = 0
0175 Do While Not rsTableControl.EOF
0176 strLine = rsTableControl.Fields(0) & ""
0177 OK = Replace_Timestamp(strLine)
0178 x = InStr(1, strLine, "**HEAD_TITLE**")
0179 If x > 0 Then
0180 strLine = Left(strLine, x - 1) & rsTableToRead.Fields(1) & " - " & rsTableToRead.Fields(2) & " (Theo Todman's Book Collection - Paper Abstracts) " & Mid(strLine, x + 14, Len(strLine))
0181 End If
0182 x = InStr(1, strLine, "**Author**")
0183 If x > 0 Then
0184 strAuthor = rsTableToRead.Fields(1)
0185 OK = Author_Reference_String(strAuthor, 2)
0186 strLine = Left(strLine, x - 1) & strAuthor & Mid(strLine, x + 10, Len(strLine))
0187 End If
0188 x = InStr(1, strLine, "**Title**")
0189 If x > 0 Then
0190 strLine = Left(strLine, x - 1) & "<A HREF = """ & "../../PaperSummaries/PaperSummary_" & Right(Str(Int(rsTableToRead.Fields(0) / 1000) + 1000000), 2) & "/" & "PaperSummary_" & rsTableToRead.Fields(0) & ".htm" & """>" & rsTableToRead.Fields(2) & "</A>" & Mid(strLine, x + 9, Len(strLine))
0191 End If
0192 x = InStr(1, strLine, "**Source**")
0193 If x > 0 Then
0194 If rsTableToRead.Fields(5) & "" <> "" Then
0195 strLine = Left(strLine, x - 1) & "Source: " & rsTableToRead.Fields(5) & Mid(strLine, x + 10, Len(strLine))
0196 Else
0197 strLine = Left(strLine, x - 1) & rsTableToRead.Fields(5) & Mid(strLine, x + 10, Len(strLine))
0198 End If
0199 End If
0200 x = InStr(1, strLine, "**LINK**")
0201 If x > 0 Then
0202 Link_Count = 0
0203 Link_1 = ""
0204 Link_2 = ""
0205 Link_3 = ""
0206 Link_4 = ""
0207 Link_5 = ""
0208 Link_6 = ""
0209 Link_Authors = ""
0210 Link_1 = "<A HREF = """ & "../../PaperSummaries/PaperSummary_" & Right(Str(Int(rsTableToRead.Fields(0) / 1000) + 1000000), 2) & "/" & "PaperSummary_" & rsTableToRead.Fields(0) & ".htm" & """>Paper Statistics</A>"
0211 Link_Count = Link_Count + 1
0212 'Output Book, Paper & Notes citing links
0213 If Test_Flag = True Then
0214 sw2.StartTimer
0215 End If
0216 strControlQuery = "SELECT Paper_Citings_List_New.* FROM Paper_Citings_List_New WHERE Paper_Citings_List_New.Paper_ID = " & rsTableToRead.Fields(0) & ";"
0217 Set rsCitings = CurrentDb.OpenRecordset(strControlQuery)
0218 If Not rsCitings.EOF Then
0219 rsCitings.MoveFirst
0220 Set rsCitings = Nothing
0221 Link_2 = "<A HREF = ""../../PaperSummaries/PaperSummary_" & Mid(rsTableToRead.Fields(0) + 1000000, 3, 2) & "/PaperCitings_" & rsTableToRead.Fields(0) & ".htm"">Books / Papers Citing this Paper</A>"
0222 Link_Count = Link_Count + 1
0223 End If
0224 If Test_Flag = True Then
0225 Debug.Print Now(); strFileName; sw2.EndTimer; "Milliseconds"; " Paper_Citings"
0226 sw2.StartTimer
0227 End If
0228 strControlQuery = "SELECT Note_Paper_Links.* FROM Note_Paper_Links WHERE Note_Paper_Links.Paper = " & rsTableToRead.Fields(0) & " AND Note_Paper_Links.Origin = ""Note"";"
0229 Set rsCitings = CurrentDb.OpenRecordset(strControlQuery)
0230 If Not rsCitings.EOF Then
0231 rsCitings.MoveFirst
0232 Link_3 = "<A HREF = ""../../PaperSummaries/PaperSummary_" & Mid(rsTableToRead.Fields(0) + 1000000, 3, 2) & "/PapersToNotes_" & rsTableToRead.Fields(0) & ".htm"">Notes Citing this Paper</A>"
0233 Link_Count = Link_Count + 1
0234 Set rsCitings = Nothing
0235 End If
0236 If Test_Flag = True Then
0237 Debug.Print Now(); strFileName; sw2.EndTimer; "Milliseconds"; " Paper_Note_Counts"
0238 End If
0239 'Add Author Citings
0240 If Test_Flag = True Then
0241 sw2.StartTimer
0242 End If
0243 strControlQuery = "SELECT Authors.Author_Name FROM Authors INNER JOIN Cross_Reference ON Authors.Author_ID = Cross_Reference.Calling_ID WHERE (((Cross_Reference.Called_ID) = " & rsTableToRead.Fields(0) & ") And ((Cross_Reference.Calling_Type) = ""A"") And ((Cross_Reference.Called_Type) = ""P"")) ORDER BY Authors.Author_Name;"
0244 Set rsCitings = CurrentDb.OpenRecordset(strControlQuery)
0245 If Not rsCitings.EOF Then
0246 rsCitings.MoveFirst
0247 Link_Authors = "<hr><p><B>Authors Citing this Paper</B>: <A HREF = ""../../Authors/" & Left(rsCitings.Fields(0), 1) & "/Author_" & rsCitings.Fields(0) & ".htm"">" & rsCitings.Fields(0) & "</A>"
0248 rsCitings.MoveNext
0249 Do While Not rsCitings.EOF
0250 strLine1 = strLine1 & ", <A HREF = ""../../Authors/" & Left(rsCitings.Fields(0), 1) & "/Author_" & rsCitings.Fields(0) & ".htm"">" & rsCitings.Fields(0) & "</A>"
0251 Link_Authors = Link_Authors & ", <A HREF = ""../../Authors/" & Left(rsCitings.Fields(0), 1) & "/Author_" & rsCitings.Fields(0) & ".htm"">" & rsCitings.Fields(0) & "</A>"
0252 rsCitings.MoveNext
0253 Loop
0254 Link_Authors = Link_Authors & "</p>"
0255 Set rsCitings = Nothing
0256 End If
0257 If Test_Flag = True Then
0258 Debug.Print Now(); strFileName; sw2.EndTimer; "Milliseconds"; " Authors Citing this Paper"
0259 End If
0260 If rsTableToRead.Fields(6) & "" <> "" Then
0261 NoteID = rsTableToRead.Fields(6)
0262 strQuery = "SELECT Note_Groups.Note_Group FROM Notes INNER JOIN Note_Groups ON Notes.Note_Group = Note_Groups.ID WHERE (((Notes.ID)=" & NoteID & "));"
0263 Set rsNote = CurrentDb.OpenRecordset(strQuery)
0264 SubDirectory = Find_New_Directory(NoteID)
0265 SubDirectory = SubDirectory & "/Notes_"
0266 If rsNote.Fields(0) = "Supervisions" Then
0267 SubDirectory = "../../Secure_Jen/Notes_" & SubDirectory
0268 Else
0269 SubDirectory = "../../Notes/Notes_" & SubDirectory
0270 End If
0271 Link_4_Saved = "<A HREF = """ & SubDirectory & rsTableToRead.Fields(6).Value & ".htm"">"
0272 Link_4 = Link_4_Saved & "Link to Latest Write-Up Note</A>"
0273 Link_Count = Link_Count + 1
0274 Else
0275 NoteID = 0
0276 End If
0277 If InStr(rsTableToRead.Fields(3), "|Colour_2|") > 0 Then
0278 If Len(rsTableToRead.Fields(3)) > 1000 Then
0279 'Advance warning for citation-text
0280 Link_5 = "<A HREF=""#ColourConventions"">Text Colour-Conventions</a>"
0281 Link_Count = Link_Count + 1
0282 End If
0283 SubDirectory = Find_New_Directory(1025)
0284 SubDirectory = SubDirectory & "/Notes_"
0285 Link_6 = "<A HREF = ""../../Notes/Notes_" & SubDirectory & "1025.htm"">Disclaimer</A>"
0286 Link_Count = Link_Count + 1
0287 End If
0288 strTable = "<CENTER><TABLE class = ""Bridge"" WIDTH=" & Link_Count * 200 & "><tr>"
0289 If Link_1 <> "" Then
0290 strTable = strTable & "<td>" & Link_1 & "</td>"
0291 End If
0292 If Link_2 <> "" Then
0293 strTable = strTable & "<td>" & Link_2 & "</td>"
0294 End If
0295 If Link_3 <> "" Then
0296 strTable = strTable & "<td>" & Link_3 & "</td>"
0297 End If
0298 If Link_4 <> "" Then
0299 strTable = strTable & "<td>" & Link_4 & "</td>"
0300 End If
0301 If Link_5 <> "" Then
0302 strTable = strTable & "<td>" & Link_5 & "</td>"
0303 End If
0304 If Link_6 <> "" Then
0305 strTable = strTable & "<td>" & Link_6 & "</td>"
0306 End If
0307 strTable = strTable & "</tr></TABLE></CENTER>"
0308 strLine = Left(strLine, x - 1) & strTable & Link_Authors & Mid(strLine, x + 8, Len(strLine))
0309 End If
0310 x = InStr(1, strLine, "**TEXT**")
0311 If x > 0 Then
0312 If Test_Flag = True Then
0313 sw2.StartTimer
0314 End If
0315 strText = "|Colour_1|"
0316 strAbstract = Trim(rsTableToRead.Fields(3) & "")
0317 strComment = Trim(rsTableToRead.Fields(4)) & ""
0318 If Len(strAbstract) > 0 Then
0319 If Len(strComment) > 3000 Then
0320 'Concatenate Abstract & Comment - Comment is overflow from Abstract
0321 strAbstract = strAbstract & strComment
0322 strComment = ""
0323 End If
0324 'Encode any unencoded references first - otherwise they never get encoded!
0325 strAbstract = ImageRef(strAbstract, "Abstract", "P", rsTableToRead.Fields(0), 0)
0326 strText = strText & strAbstract
0327 Else
0328 strAbstract = ""
0329 End If
0330 If strComment <> "" Then
0331 If Len(strComment) > 0 Then
0332 'Encode any unencoded references first - otherwise they never get encoded!
0333 strComment = ImageRef(strComment, "Abstract", "P", rsTableToRead.Fields(0), 0)
0334 strText = strText & IIf(Len(strAbstract) > 0, "<hr>", "") & "|Colour_1|<B>Comment: </B>" & IIf(Left(strComment, 1) = "|", "", "<BR><BR>") & strComment & "<BR>"
0335 End If
0336 End If
0337 'Write out Write-up Note (if any)
0338 If NoteID > 0 Then
0339 strQuery = "SELECT Notes.ID, Notes.Item_Title, Notes.Item_Text, Notes.Last_Changed, Notes.[Private?] FROM Notes WHERE (((Notes.ID)=" & NoteID & "));"
0340 Set rsNote = CurrentDb.OpenRecordset(strQuery)
0341 If Not rsNote.EOF Then
0342 If rsNote.Fields(4) & "" = "No" Then
0343 strNote_Date = rsNote.Fields(3) & ""
0344 If strNote_Date <> "" Then
0345 strNote_Date = CDate(strNote_Date / 1000)
0346 Else
0347 strNote_Date = Now()
0348 End If
0349 strText = strText & "|Colour_1|<hr><br><B><u>Write-up++FN|..||.|This is the write-up as it was when this Abstract was last output, with text as at the timestamp indicated (" & strNote_Date & "). |.|" & Link_4 & ". |..|++</u> (as at " & strNote_Date & "): " & Link_4_Saved & rsNote.Fields(1) & "</a></B><BR><br>" & ImageRef(rsNote.Fields(2), "Abstract", "P", rsTableToRead.Fields(0), 0)
0350 End If
0351 End If
0352 End If
0353 'In-page Footnotes, Etc.
0354 OK = Reference_FootNotes("P", rsTableToRead.Fields(0), strText)
0355 strText = strText & "|Colour_1|<HR>"
0356 strLine = Left(strLine, x - 1) & strText & Mid(strLine, x + 8, Len(strLine))
0357 strLine = Remove_Dummy_Ref(strLine)
0358 strLine = WebEncode(strLine)
0359 OK = Mark_Colours(strLine)
0360 OK = Reference_Files(strLine, "P", rsTableToRead.Fields(0), 0) 'Replace the PDF Files References by hyperlinks
0361 OK = Reference_Notes(strLine, "P", rsTableToRead.Fields(0), 0, 2, "Abstract_Direct", "Paper", rsTableToRead.Fields(0)) 'Replace the Notes References by hyperlinks
0362 OK = Reference_Notes(strLine, "P", rsTableToRead.Fields(0), 0, 2, "Abstract", "Paper", rsTableToRead.Fields(0)) 'Replace the Notes References by hyperlinks
0363 OK = Reference_Papers(strLine, "P", rsTableToRead.Fields(0), 0) 'Replace the Papers References by hyperlinks
0364 OK = Reference_Author(strLine, "P", rsTableToRead.Fields(0), 0) 'Replace the Author References by hyperlinks
0365 OK = Reference_Note_Links(strLine, "P", rsTableToRead.Fields(0), 0) 'Replace the Note_Link References by hyperlinks
0366 OK = Reference_Books(strLine, "P", rsTableToRead.Fields(0), 0) 'Replace the Books References by hyperlinks
0367 OK = Reference_Webrefs(strLine, "P", rsTableToRead.Fields(0), 0)
0368 OK = Reference_Reference(strLine)
0369 OK = Reference_Code(strLine)
0370 OK = Reference_Queries(strLine)
0371 OK = Reference_Tables(strLine)
0372 strLine = ReplaceCode(strLine, Chr(13) & Chr(10), "<BR>")
0373 'Bullets
0374 strLine = NumberedBullets(strLine)
0375 strLine = Bullets(strLine)
0376 strLine = strLine & "<a name=""ColourConventions""></a><p><b>Text Colour Conventions (see <A HREF=""../../Notes/Notes_10/Notes_1025.htm"">disclaimer</a>)</b></p><OL TYPE=""1"">"
0377 For i = 0 To 19
0378 If Colour_Table(i, 4) = "1" Then
0379 strLine = strLine & "<LI><FONT COLOR = """ & Colour_Table(i, 1) & """>" & Colour_Table(i, 2) & "</FONT>: " & Colour_Table(i, 3) & "</li>"
0380 End If
0381 Next i
0382 strLine = strLine & "</OL>"
0383 If Test_Flag = True Then
0384 Debug.Print Now(); strFileName; sw2.EndTimer; "Milliseconds"; " Process Text"
0385 End If
0386 End If
0387 'Write out
0388 If strLine <> "<tr><th></th></tr>" Then 'A bit of a fudge ... supposed to pick up where no source
0389 tsTextFile.WriteLine strLine
0390 End If
0391 rsTableControl.MoveNext
0392 Loop
0393 'Log Referencing Changes
0394 If Test_Flag = True Then
0395 sw2.StartTimer
0396 End If
0397 If Full_Regen = False Then
0398 DoCmd.OpenQuery ("Cross_Reference_Changes_Deletions_Add")
0399 End If
0400 If Test_Flag = True Then
0401 Debug.Print Now(); strFileName; sw2.EndTimer; "Milliseconds"; " Cross_Reference_Changes_Deletions_Add"
0402 End If
0403 If Test_Flag = True Then
0404 sw2.StartTimer
0405 End If
0406 If Full_Regen = False Then
0407 DoCmd.OpenQuery ("Cross_Reference_Changes_Additions_Add")
0408 End If
0409 If Test_Flag = True Then
0410 Debug.Print Now(); strFileName; sw2.EndTimer; "Milliseconds"; " Cross_Reference_Changes_Additions_Add"
0411 End If
0412 'Copy to Transfer
0413 If Test_Flag = True Then
0414 sw2.StartTimer
0415 End If
0416 OK = CopyToTransfer(strFolder, strFileName)
0417 If Test_Flag = True Then
0418 Debug.Print Now(); strFileName; sw2.EndTimer; "Milliseconds"; " CopyToTransfer"
0419 Debug.Print Now(); strFileName; sw.EndTimer; "Milliseconds"
0420 Stop
0421 End If
0422 iCount = iCount + 1
0423 rsTableToRead.MoveNext
0424 Loop
0425 If Run_Type <> "Changed" And Run_Type <> "Selected" Then
0426 'Update the Paper_Abstract_Ranges Table
0427 Duration = Now() - StartTime
0428 Duration = Duration * 24 * 60
0429 Duration = Round(Duration, 1)
0430 RunDate = Now()
0431 rsTableToRead2.Edit
0432 rsTableToRead2.Fields(4) = RunDate
0433 rsTableToRead2.Fields(5) = Duration
0434 rsTableToRead2.Update
0435 'Read Next Range
0436 rsTableToRead2.MoveNext
0437 If rsTableToRead2.EOF Then
0438 All_Done = True
0439 End If
0440 StartTime = Now()
0441 End If
0442Loop
0443Set rsNotePaperLinksDB = Nothing
0444Set rsTableToRead = Nothing
0445Set rsTableToRead2 = Nothing
0446Cross_Reference_Table_Open = False
0447Set rsCross_Reference_Table = Nothing
0448If Test_Flag = True Then
0449 Set sw = Nothing
0450 Set sw2 = Nothing
0451End If
0452 DoCmd.OpenQuery ("Cross_Reference_Idempotency_Zap")
0453If automatic_processing <> "Yes" Then
0454 Duration = Round((Now() - RunStartTime) * 24 * 60, 1)
0455 If Duration < 1 Then
0456 Duration = Round((Now() - RunStartTime) * 24 * 60 * 60)
0457 MsgBox Now() & ": Abstract Webpage Creation Complete in " & Duration & " seconds. " & iCount & " pages output.", vbOKOnly, "Create Paper Abstract Web Pages"
0458 Else
0459 MsgBox Now() & ": Abstract Webpage Creation Complete in " & Duration & " minutes. " & iCount & " pages output.", vbOKOnly, "Create Paper Abstract Web Pages"
0460 End If
0461End If
0462End Sub

Procedures Calling This Procedure (CreateAbstractWebPages) Procedures Called By This Procedure (CreateAbstractWebPages) Tables / Queries / Fragments Directly Used By This Procedure (CreateAbstractWebPages) Go To Start of This Procedure
Go To Top of This Page
Link to VBA Code Control Page



Source Code of: CreateModulesWebpage
Procedure Type: Public Sub
Module: Documentation
Lines of Code: 60
Go To End of This Procedure

Line-No. / Ref.Code Line
0001Public Sub CreateModulesWebpage()
0002Dim rsTableControl As Recordset
0003Dim strControlQuery As String
0004Dim strLine As String
0005Dim iTableColumns As Integer
0006Dim strFileSuffix As String
0007Dim Procedure_Type As String
0008Dim Heading As String
0009Dim rsTableToRead As Recordset
0010Dim Module As String
0011'Create the Documentation_Code_Modules File
0012'Read the data
0013 strDataQuery = "SELECT Code_Table.Module FROM Code_Table GROUP BY Code_Table.Module ORDER BY Code_Table.Module;"
0014Set rsTableToRead = CurrentDb.OpenRecordset(strDataQuery)
0015rsTableToRead.MoveFirst
0016'Create File
0017strOutputFileShort = SubSystem & "Documentation_Code_Modules"
0018Set tsTextFile = fsoTextFile2.CreateTextFile(strOutputFolder & strOutputFileShort & ".htm", True, True)
0019'Create Page Header
0020 strControlQuery = "SELECT Website_Control.Line_Value FROM Website_Control WHERE (((Website_Control.Web_Page) = """ & strControlTable & """) And ((Website_Control.Section) = ""Header"")) ORDER BY Website_Control.Line;"
0021Set rsTableControl = CurrentDb.OpenRecordset(strControlQuery)
0022rsTableControl.MoveFirst
0023Do While Not rsTableControl.EOF
0024 strLine = rsTableControl.Fields(0) & ""
0025 tsTextFile.WriteLine strLine
0026 rsTableControl.MoveNext
0027Loop
0028'Create Main Jump Table
0029iTableColumns = 5
0030Procedure_Type = "Modules"
0031Heading = "Modules"
0032 OK = CreateDocumentationJumpTables(Procedure_Type, Heading, iTableColumns)
0033Do While Not rsTableToRead.EOF
0034 Module = rsTableToRead.Fields(0).Value
0035 'Create Module Jump Table
0036 iTableColumns = 5
0037 Procedure_Type = "Modules"
0038 Heading = "Module: " & Module
0039 OK = CreateDocumentationJumpTables(Procedure_Type, Heading, iTableColumns, Module)
0040 rsTableToRead.MoveNext
0041Loop
0042'Create link to main code jump-table
0043 strLine = "<A HREF=""" & SubSystem & "DocumentationControl.htm"">Link to VBA Code Control Page</A><br>"
0044tsTextFile.WriteLine strLine
0045'Finish File
0046'Page Footer
0047 strControlQuery = "SELECT Website_Control.Line_Value FROM Website_Control WHERE (((Website_Control.Web_Page) = """ & strControlTable & """) And ((Website_Control.Section) = ""Footer"")) ORDER BY Website_Control.Line;"
0048Set rsTableControl = CurrentDb.OpenRecordset(strControlQuery)
0049rsTableControl.MoveFirst
0050Do While Not rsTableControl.EOF
0051 strLine = rsTableControl.Fields(0)
0052 OK = Replace_Timestamp(strLine)
0053 tsTextFile.WriteLine strLine
0054 rsTableControl.MoveNext
0055Loop
0056'Copy to Transfer
0057strFileSuffix = strOutputFileShort
0058 OK = CopyToTransfer(strFolder, strFileSuffix & ".htm")
0059Set tsTextFile = Nothing
0060End Sub

Procedures Calling This Procedure (CreateModulesWebpage) Procedures Called By This Procedure (CreateModulesWebpage) Tables / Queries / Fragments Directly Used By This Procedure (CreateModulesWebpage) Go To Start of This Procedure
Go To Top of This Page
Link to VBA Code Control Page



Source Code of: Webrefs_Update
Procedure Type: Public Sub
Module: Spider
Lines of Code: 406
Go To End of This Procedure

Line-No. / Ref.Code Line
0001Public Sub Webrefs_Update()
0002Dim ie As InternetExplorer
0003Dim rsTableControl As Recordset
0004Dim i As Integer
0005Dim j As Integer
0006Dim k As Integer
0007Dim Requested_URL
0008Dim Returned_URL
0009Dim start As Date
0010Dim RunTime As Single
0011Dim Running_Hours As Single
0012Dim Issue As String
0013Dim Defunct As Boolean
0014Dim Update_Time As Double
0015Dim Recent_Check_Days As Single
0016Dim Recent_Check_Date As Single
0017Dim Recent_Check As Date
0018Dim Recent_Check_OK As Boolean
0019Dim Last_Bounce As Date
0020Dim Given_Up As Boolean
0021Dim Uncheckable As Boolean
0022Dim strQuery As String
0023Dim sBounce As Single
0024Dim max_Checks As Integer
0025Dim Webrefs_Option As String
0026Dim Option_Help As String
0027Dim Issue_Check As String
0028Dim YouTube_Check_Sent As String
0029Dim YouTube_Check_Returned As String
0030Dim Debug_Print As String
0031Dim Returned_URL_Saved As String
0032Dim Forced_Bounce As Boolean
0033Dim strMessage As String
0034Dim z As Integer
0035Dim Check_Text As String
0036Dim Check_404 As Boolean
0037Dim Start_Time As Double
0038Dim TagNames(100) As String
0039Dim iTags As Integer
0040'Note: this Sub checks all recorded URLs in my website against the Web, and records the results
0041'Adjust the parameters below if needs-be ...
0042Recent_Check_Days = 10
0043Recent_Check_Date = Now() - Recent_Check_Days
0044Recent_Check = Now() - Recent_Check_Days 'Parameter - Check gap in days
0045RunTime = 5 'Parameter - run time in hours
0046sBounce = 5 'IE Bounce time in minutes
0047max_Checks = 20 'In seconds I tried 5 minutes, but most previous time-outs seemed OK after 10 seconds
0048Option_Help = "Parameters are:- " & Chr$(10) & "... Check after " & Recent_Check_Days & " days"
0049Option_Help = Option_Help & Chr$(10) & "... Max run-time = " & RunTime & " hours"
0050Option_Help = Option_Help & Chr$(10) & "... Bounce IE after " & sBounce & " minutes"
0051Option_Help = Option_Help & Chr$(10) & "... Max checks = " & max_Checks
0052Option_Help = Option_Help & Chr$(10) & "Choose an Option:-"
0053Option_Help = Option_Help & Chr$(10) & "1. Run Full Check"
0054Option_Help = Option_Help & Chr$(10) & "2. Run Check for New Links since last run"
0055Option_Help = Option_Help & Chr$(10) & "3. Run for Time-outs when last checked"
0056Webrefs_Option = InputBox(Option_Help, "Enter an integer Spider Option", 1)
0057If Len(Webrefs_Option) = 0 Then
0058 End
0059End If
0060If Webrefs_Option < "1" Or Webrefs_Option > "3" Then
0061 MsgBox ("Choose an Option between 1 and 3")
0062 End
0063End If
0064Select Case Webrefs_Option
0065 Case 1
0066 strQuery = "SELECT * FROM Webrefs_Table WHERE (((Webrefs_Table.[Defunct?]) = False) And (([Date_Last_Checked] + 0) < " & Recent_Check_Date & ") And ((Webrefs_Table.Issue) <> ""Manual Check OK"")) Or (((Webrefs_Table.[Defunct?]) = False) And (([Date_Last_Checked] + 0) < " & Recent_Check_Date & ") And ((Webrefs_Table.Issue) Is Null)) ORDER BY Webrefs_Table.ID;"
0067 Case 2
0068 strQuery = "SELECT * FROM Webrefs_Table WHERE (((Webrefs_Table.[Defunct?]) = False) And (([Date_Last_Checked] & """") = """")) ORDER BY Webrefs_Table.ID;"
0069 Case 3
0070 strQuery = "SELECT * FROM Webrefs_Table WHERE (((Webrefs_Table.[Defunct?]) = False) And ((Webrefs_Table.Issue) = ""Timeout"")) ORDER BY Webrefs_Table.ID;"
0071 Recent_Check_Days = 0.5 / 24
0072 max_Checks = 60
0073 Recent_Check = Now() - Recent_Check_Days 'Parameter - Check gap in days - reset for Timeouts
0074 MsgBox ("Recent check parameter reset to half an hour & max checks to 60 - 1 minute - for Timeout-checker")
0075 Case Else
0076 End
0077End Select
0078Start_Time = Now()
0079Set rsTableControl = CurrentDb.OpenRecordset(strQuery)
0080If rsTableControl.EOF Then
0081 MsgBox "Nothing to do!"
0082 End
0083Else
0084 DoEvents
0085 rsTableControl.MoveLast
0086 DoEvents
0087End If
0088strMessage = "References yet to check = " & rsTableControl.RecordCount
0089Debug.Print Now() & " - "; strMessage
0090MsgBox (strMessage)
0091start = Now()
0092Debug.Print Now() & " - "; "Webrefs_Update Started"
0093Debug.Print Now() & " - "; "Webrefs_Update: " & strMessage
0094strMessage = "Last References to check = " & rsTableControl.Fields(0)
0095rsTableControl.MoveFirst
0096strMessage = "First References to check = " & rsTableControl.Fields(0) & "; " & strMessage
0097Debug.Print Now() & " - "; "Webrefs_Update: " & strMessage
0098'Open Internet Explorer in memory, and go to website
0099Set ie = New InternetExplorer
0100'ie.Visible = False
0101Last_Bounce = start
0102Returned_URL_Saved = "zzz"
0103Forced_Bounce = False
0104z = 1
0105Do While Not rsTableControl.EOF
0106 'Bounce IE every sBounce minutes
0107 If ((Now() - Last_Bounce) * 24 * 60 > sBounce) Or Forced_Bounce = True Then
0108 DoEvents
0109 ie.Quit
0110 Set ie = Nothing
0111 Set ie = New InternetExplorer
0112 'ie.Visible = False
0113 Last_Bounce = Now()
0114 If Forced_Bounce = True Then
0115 strMessage = "Forced Bounce: "
0116 Forced_Bounce = False
0117 Else
0118 strMessage = "Regular Bounce: "
0119 End If
0120 Debug.Print Now() & " - " & strMessage & "IE Bounced at " & Last_Bounce & " - Count = " & z & ". Id=" & rsTableControl.Fields(0)
0121 End If
0122 Uncheckable = False
0123 'Check if updated recently
0124 Recent_Check_OK = True
0125 If rsTableControl.Fields(4) > Recent_Check Then
0126 Recent_Check_OK = False
0127 End If
0128 Requested_URL = rsTableControl.Fields(1)
0129 If Right(Requested_URL, 4) = ".doc" Or Right(Requested_URL, 5) = ".docx" Or Right(Requested_URL, 4) = ".mp3" Or Right(Requested_URL, 4) = ".pps" Then 'Word or PowerPoint docs can't be saved automatically & mp3s loop ....
0130 Uncheckable = True
0131 Recent_Check_OK = False
0132 Issue = "File Type Uncheckable"
0133 End If
0134 Update_Time = Now()
0135 Given_Up = False
0136 If Recent_Check_OK = True Then
0137Resume_Here:
0138 Defunct = False
0139 Issue = ""
0140 On Error GoTo Err_Fix
0141 ie.Navigate Requested_URL
0142 Update_Time = Now()
0143 'Wait until IE is done loading page
0144 i = 1
0145 Returned_URL = ""
0146 If Err.Number <= 0 Then
0147 Do While ((ie.ReadyState < READYSTATE_COMPLETE) Or (Returned_URL = "")) And (Given_Up = False)
0148 DoEvents
0149 If ie.LocationURL & "" <> Returned_URL_Saved Then
0150 Returned_URL = ie.LocationURL
0151 End If
0152 i = i + 1
0153 If i > max_Checks Then
0154 Given_Up = True
0155 Issue = "Timeout"
0156 Forced_Bounce = True
0157 End If
0158 WaitFor (1) 'Wait 1 second, then check again
0159 If Err.Number > 0 Then
0160 GoTo Err_Fix
0161 End If
0162 Loop
0163 Else
0164 GoTo Err_Fix
0165 End If
0166 If Given_Up = False Then
0167 'Stick a test in here! This is mostly for future use ..
0168 For k = 1 To 100
0169 TagNames(i) = ""
0170 Next k
0171 iTags = 0
0172 On Error Resume Next 'Seems to work OK most of the time ... if it fails on the next line, "Object doesn't support this property or method" try terminating, compact & repair, and re-start. It's probably a recovery problem of some sort which I can't be bothered to resolve
0173 iTags = ie.Document.GetElementsByTagName("*").Length
0174 Err.Clear
0175 If InStr(Requested_URL, ".pdf") > 0 Then
0176 If iTags > 0 Then
0177 'If it really were a .pdf, iTags would be 0, so ...
0178 Issue = "PDF Not Found"
0179 End If
0180 End If
0181 If iTags > 100 Then
0182 iTags = 100
0183 End If
0184 If iTags > 0 Then
0185 'Debug.Print iTags
0186 For k = 1 To iTags
0187 TagNames(i) = ie.Document.GetElementsByTagName("*")(i).TagName
0188 'Debug.Print TagNames(i)
0189 Next k
0190 End If
0191 'Proceed ...
0192 Returned_URL = ""
0193 Returned_URL = ie.LocationURL
0194 If Requested_URL = Returned_URL Then
0195 If InStr(Requested_URL, ".pdf") = 0 Then
0196 On Error Resume Next 'Didn't work ...
0197 Returned_URL = ie.Document.URL 'Some documents don't support this ... if so, comment out, step over, and uncomment ready for the next page
0198 Err.Clear
0199 On Error GoTo Err_Fix
0200 End If
0201 End If
0202 Returned_URL_Saved = Returned_URL
0203 If (Requested_URL <> Returned_URL) Then
0204 If (Replace(Returned_URL, "https", "http") = Requested_URL) And (Issue <> "PDF Not Found") Then
0205 Issue = "URL Secured"
0206 Else
0207 If ((Requested_URL & "/" = Returned_URL) Or (Requested_URL = Returned_URL & "/")) And (Issue <> "PDF Not Found") Then
0208 Issue = "URL with trailing slash"
0209 Else
0210 If InStr(Returned_URL, "http://www.webaddresshelp.bt.com") > 0 And (Issue <> "PDF Not Found") Then
0211 Issue = "URL Not found"
0212 Defunct = True
0213 Forced_Bounce = True
0214 Else
0215 If (Left(Returned_URL, Len("http://web.demo.barefruit.co.uk/")) = "http://web.demo.barefruit.co.uk/") And (Issue <> "PDF Not Found") Then
0216 Issue = "URL Not Found"
0217 Defunct = True
0218 Forced_Bounce = True
0219 Else
0220 If Right(Returned_URL, 4) <> ".pdf" Then
0221 On Error Resume Next 'Didn't work ...
0222 Check_Text = ""
0223 If ie.Document.GetElementsByTagName("title").Length > 0 Then
0224 Check_Text = ie.Document.GetElementsByTagName("title")(0).innerHtml
0225 End If
0226 If ie.Document.GetElementsByTagName("h1").Length > 0 Then
0227 Check_Text = Check_Text & ie.Document.GetElementsByTagName("h1")(0).innerHtml
0228 End If
0229 'Probably could add other elements above ... ?
0230 If InStr(Check_Text, "404") > 0 Then
0231 If Issue <> "PDF Not Found" Then
0232 Issue = "Page Not Found"
0233 End If
0234 Defunct = True
0235 Else
0236 If InStr(Check_Text, "403") > 0 Then
0237 Issue = "Access Denied"
0238 Defunct = True
0239 End If
0240 End If
0241 If Issue = "" Then
0242 Issue = "URL Differs"
0243 End If
0244 Err.Clear
0245 On Error GoTo Err_Fix
0246 Else
0247 Issue = "PDF Not Found"
0248 End If
0249 End If
0250 End If
0251 End If
0252 End If
0253 End If
0254 If Issue = "" Then
0255 'Check Aeon or Psyche "page not found" ...
0256 If (InStr(Requested_URL, "https://aeon.co/") > 0 And Len(Requested_URL) > Len("https://aeon.co/about/")) Or (InStr(Requested_URL, "https://psyche.co/") > 0 And Len(Requested_URL) > Len("https://psyche.co/about/")) Then
0257 Check_404 = False
0258 For j = 0 To ie.Document.GetElementsByTagName("p").Length - 1
0259 Check_Text = ie.Document.GetElementsByTagName("p")(j).innerHtml
0260 If InStr(Check_Text, "(404)") > 0 Then
0261 Check_404 = True
0262 j = 30
0263 End If
0264 Next j
0265 If Check_404 = True Then
0266 Issue = "Page Not Found"
0267 Defunct = True
0268 End If
0269 End If
0270 End If
0271 If Issue = "" Then
0272 'Check Wikipedia "page not found" ...
0273 If InStr(Requested_URL, "https://en.wikipedia.org/wiki/") > 0 Then
0274 Check_404 = False
0275 For j = 0 To ie.Document.GetElementsByTagName("BODY").Length - 1
0276 Check_Text = ie.Document.GetElementsByTagName("BODY")(j).innerHtml
0277 If InStr(Check_Text, "Wikipedia does not have an article with this exact name") > 0 Then
0278 Check_404 = True
0279 j = 30
0280 End If
0281 Next j
0282 If Check_404 = True Then
0283 Issue = "Page Not Found"
0284 Defunct = True
0285 End If
0286 End If
0287 End If
0288 If Issue = "" Then
0289 If Right(Returned_URL, 4) <> ".pdf" Then
0290 On Error Resume Next 'Didn't work ...
0291 Check_Text = ""
0292 If ie.Document.GetElementsByTagName("title").Length > 0 Then
0293 Check_Text = ie.Document.GetElementsByTagName("title")(0).innerHtml
0294 End If
0295 If InStr(Check_Text, "404") > 0 Then
0296 Issue = "Page Not Found"
0297 Defunct = True
0298 Else
0299 If ie.Document.GetElementsByTagName("h1").Length > 0 Then
0300 Check_Text = ie.Document.GetElementsByTagName("h1")(0).innerHtml
0301 End If
0302 If InStr(Check_Text, "404") > 0 Then
0303 Issue = "Page Not Found"
0304 Defunct = True
0305 End If
0306 End If
0307 Err.Clear
0308 On Error GoTo Err_Fix
0309 End If
0310 End If
0311 End If
0312 If Issue = "URL Differs" Then
0313 If InStr(Requested_URL, "youtube") > 0 Then
0314 'Check for YouTube time issues
0315 j = InStr(Requested_URL, "&t=")
0316 If j > 0 Then
0317 YouTube_Check_Sent = Left(Requested_URL, j - 1)
0318 Else
0319 YouTube_Check_Sent = Requested_URL
0320 End If
0321 j = InStr(Returned_URL, "&t=")
0322 If j > 0 Then
0323 YouTube_Check_Returned = Left(Requested_URL, j - 1)
0324 Else
0325 YouTube_Check_Returned = Requested_URL
0326 End If
0327 If YouTube_Check_Sent = YouTube_Check_Returned Then
0328 Issue = ""
0329 Else
0330 Forced_Bounce = True
0331 End If
0332 Else
0333 Forced_Bounce = True
0334 End If
0335 If InStr(Returned_URL, "res://ieframe.dll") > 0 Then
0336 Debug.Print Now() & " - Count = " & z & ". " & "Id=" & rsTableControl.Fields(0) & ". Returned_URL: "; Returned_URL
0337 Issue = "URL Not found"
0338 Returned_URL = ""
0339 End If
0340 End If
0341 If Issue = "URL Not Found" Then
0342 Defunct = True
0343 Issue_Check = Right(Requested_URL, 6)
0344 If (InStr(Issue_Check, ".htm") > 0) Or (InStr(Issue_Check, ".html") > 0) Or (InStr(Issue_Check, ".shtm") > 0) Or (Right(Issue_Check, 1) = "/") Then
0345 Issue = "Page Not Found"
0346 Else
0347 If InStr(Issue_Check, ".") > 0 Then
0348 Issue = "Document Not Found"
0349 Else
0350 Issue = "Page Not Found"
0351 End If
0352 End If
0353 End If
0354 rsTableControl.Edit
0355 rsTableControl.Fields(4) = Now()
0356 If Issue = "URL Differs" Then
0357 rsTableControl.Fields(5) = Left(Returned_URL, 255)
0358 Else
0359 rsTableControl.Fields(5) = ""
0360 End If
0361 rsTableControl.Fields(6) = Issue
0362 rsTableControl.Fields(7) = i
0363 Update_Time = (Now() - Update_Time) * 24 * 60 * 60
0364 rsTableControl.Fields(8) = Update_Time
0365 rsTableControl.Fields(9) = Defunct
0366 rsTableControl.Update
0367 If Issue <> "" Then
0368 Debug_Print = " Issue = " & Issue
0369 Else
0370 Debug_Print = ""
0371 End If
0372 Debug_Print = Now() & " - Count = " & z & "." & Debug_Print & " Id=" & rsTableControl.Fields(0) & ", Tries = " & i & " Requested_URL = " & Requested_URL
0373 z = z + 1
0374 If Issue = "URL Differs" Then
0375 Debug_Print = Debug_Print & " Returned_URL = " & Returned_URL
0376 End If
0377 If Issue <> "" Then
0378 Debug.Print Debug_Print
0379 End If
0380 End If
0381 rsTableControl.MoveNext
0382 Running_Hours = (Now() - start) * 24
0383 If Running_Hours > RunTime Then
0384 Stop
0385 start = Now()
0386 End If
0387Loop
0388ie.Quit
0389Set ie = Nothing
0390Start_Time = Round((Now() - Start_Time) * 24 * 60, 1)
0391 Debug_Print = Now() & " - Webrefs_Update Completed in " & Start_Time & " minutes."
0392Debug.Print Debug_Print
0393MsgBox "Webrefs Checker Completed at " & Now() & " in " & Start_Time & " minutes."
0394Exit Sub
0395Err_Fix:
0396Debug.Print Now() & " - Id=" & rsTableControl.Fields(0) & " " & Err.Description
0397DoEvents
0398Err.Clear
0399Set ie = Nothing
0400Set ie = New InternetExplorer
0401'ie.Visible = False
0402Last_Bounce = Now()
0403Forced_Bounce = False
0404Debug.Print Now() & " - "; "Error Bounce: IE Bounced at " & Last_Bounce
0405GoTo Resume_Here
0406End Sub

Procedures Calling This Procedure (Webrefs_Update) Procedures Called By This Procedure (Webrefs_Update) Tables / Queries / Fragments Directly Used By This Procedure (Webrefs_Update) Go To Start of This Procedure
Go To Top of This Page
Link to VBA Code Control Page



© Theo Todman, June 2007 - March 2026. Please address any comments on this page to theo@theotodman.com. File output:
Website Maintenance Dashboard
Return to Top of this Page Return to Theo Todman's Philosophy Page Return to Theo Todman's Home Page