/*----------------------------------------------------------------------------*/ /* */ /* Copyright (c) 2002-2022 Rony G. Flatscher. All rights reserved. */ /* Copyright (c) 2023 Rexx Language Association. All rights reserved. */ /* */ /* This program and the accompanying materials are made available under */ /* the terms of the Common Public License v1.0 which accompanies this */ /* distribution. A copy is also available at the following address: */ /* https://www.oorexx.org/license.html */ /* */ /* Redistribution and use in source and binary forms, with or */ /* without modification, are permitted provided that the following */ /* conditions are met: */ /* */ /* Redistributions of source code must retain the above copyright */ /* notice, this list of conditions and the following disclaimer. */ /* Redistributions in binary form must reproduce the above copyright */ /* notice, this list of conditions and the following disclaimer in */ /* the documentation and/or other materials provided with the distribution. */ /* */ /* Neither the name of Rexx Language Association nor the names */ /* of its contributors may be used to endorse or promote products */ /* derived from this software without specific prior written permission. */ /* */ /* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS */ /* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT */ /* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS */ /* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT */ /* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, */ /* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED */ /* TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, */ /* OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY */ /* OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING */ /* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS */ /* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ /* */ /*----------------------------------------------------------------------------*/ /*********************************************************************** program: oleinfo2html.frm purpose: Query the OLE/ActiveX automation interface, create HTML renderings of results needs: oleinfo.cls usage: require this file oleinfo(app_name[, [oleobj] [, [bCompact] [, HTMLString]]] ) app_name OLE/ActiveX program name or class-id oleobj OLE object, .nil or empty string ... if .nil or empty string, an OLE object is created with app_name bCompact ... .true=compact rendering, .false=full rendering including constants HTMLString ... if given, gets inserted right before tables begin returns: array with two elements: string of
and string of ***********************************************************************/ nl="0d0a"x parse source . . thisPgm thisLocation=filespec('location',thisPgm) -- create a stylesheet link with a fully quailified name in addition to one without a path -- oleinfo.properties propsFile="oleinfo.properties" if \sysFileExists(propsFile) then propsFile=thisLocation||propsFile if sysFileExists(propsFile) then do props=.Properties~load(propsFile) stylesheet =props~getProperty("cssFileName", stylesheet)~strip bIncorporateCss=props~getLogical("incorporateCSS", .true) end else -- no cssFile found, just refer to it, do not attempt to incorporate do stylesheet ="oleinfo.css" bIncorporateCss=.false end if bIncorporateCss then -- does stylesheet exist? do if \sysFileExists(stylesheet) then do tmpStyleSheet=thisLocation||stylesheet if sysFileExists(tmpStyleSheet) then styleSheet=tmpStyleSheet else -- does not exist, do not incorporate CSS, leave original name intact bIncorporateCss=.false end end tmpLocalCss="" if bIncorporateCss then -- if .true get css-definitions and copy them into the head do s=.stream~new(stylesheet)~~open("read") tmp="" nl -- incorporate css definitions s~close end else do tmp=stream(stylesheet, "c", "query exists") if tmp="" then -- hmm, not found, maybe wer are not in our home directory, try it with that do errMsg="Problem, cannot locate stylesheet:" stylesheet if window <> "WINDOW" then call alert msg else .error~say(msg) end tmpLocalCss=' ' if tmp <> "" then do tmp=' 'nl , ' ' end else tmp="" end -- HTML head text .local~head.text = , ' 'nl , ' 'nl , ' 'nl , ' 'nl , 'Effective ProgID: ['a~oleobject~progid']' call sag 'CLSID: ['a~oleobject~clsid']
' end call sag '' call sag '
' o=a~methodDir -- get method directory from OLEInfo object if bBrowser then -- assuming to run under WWW-browser window~status='Analyzing and creating HTML-text for available' o~items 'methods ...' call sag call sag '
show', '' call sag ' | ' '' a~methodDir~items 'Method[s]' '' call sag ' | |||||
---|---|---|---|---|---|---|
No. | Name | Documentation, Argument[s], Return Value'
call sag ' | ||||
'm ' | ' ts.i , ' | ' ot~doc~string '' ' ' call sag call sag '
|
' o=a~getOnlyPropertyDir -- get directory with the read-only properties from OLEinfo object if bBrowser then -- assuming to run under WWW-browser window~status='Analyzing and creating HTML-text for available' o~items 'read-only properties ...' call sag call sag '
show', '' call sag ' | ' '' a~getOnlyPropertyDir~items 'Read-only Properties' '' call sag ' | |||||
---|---|---|---|---|---|---|
No. | Name | Documentation, Return Value'
call sag ' | ||||
'm ' | ' ts.i ' | ' ot~doc~string '' ' ' call sag ' | ||||
'm ' | ' ts.i , ' | ' ot~doc~string '' ' ' call sag call sag '
|
' o=a~putOnlyPropertyDir -- get write-only property from OLEinfo object if bBrowser then -- assuming to run under WWW-browser window~status='Analyzing and creating HTML-text for available' o~items 'write-only properties ...' call sag call sag '
show', '' call sag ' | ' '' a~putOnlyPropertyDir~items 'Write-only Properties' '' call sag ' | |||||
---|---|---|---|---|---|---|
No. | Name | Documentation, Argument[s], Return Value'
call sag ' | ||||
'm ' | ' ts.i ' | ' ot~doc~string '' ' ' call sag ' | ||||
'm ' | ' ts.i , ' | ' ot~doc~string '' ' ' call sag call sag '
|
' o=a~getAndPutPropertyDir if bBrowser then -- assuming to run under WWW-browser window~status='Analyzing and creating HTML-text for available' o~items 'read/write properties ...' call sag call sag '
show', '' call sag ' | ' '' a~getAndPutPropertyDir~items 'Read/Write Properties' '' call sag ' | |||||
---|---|---|---|---|---|---|
No. | Name | Documentation, Argument[s], Return Value'
call sag ' | ||||
'm ' | ' ts.i ' | ' ot~doc~string'' ' ' call sag ' | ||||
'm ' | ' ts.i , ' | ' ot~doc~string '' ' ' call sag call sag '
|
' o=a~naDir if bBrowser then -- assuming to run under WWW-browser window~status='Analyzing and creating HTML-text for available' o~items 'unknown invocation types ...' call sag call sag '
show', '' call sag ' | ' '' a~naDir~items 'Methods with Unknown Invocation Type Properties' '' call sag ' | ||||||||
---|---|---|---|---|---|---|---|---|---|
No. | Name | Documentation, Argument[s], Return Value'
call sag ' | |||||||
'm ' | ' ts.i ' | ' ' ' call sag ' 'm ' | ' ts.i ,
' | ' ot~doc~string '' ' | ' call sag 'Invocation type:' ot~invkind "(".rgf.invKind[ot~invkind]")" ' ' call sag call sag '
' end call sag end call sag ' |
' o=a~eventDir if bBrowser then -- assuming to run under WWW-browser window~status='Analyzing and creating HTML-text for available' o~items 'events ...' call sag call sag '
show', '' call sag ' | ' '' a~eventDir~items 'Event(s)' '' call sag ' | |||
---|---|---|---|---|
No. | Name | Documentation, Argument[s], Return Value'
call sag ' | ||
'm ' | ' ts.i , ' | ' ot~doc~string '' ' ' if ot~params~items > 0 then do call sag call sag '
|
' call sag call sag '
show', '' call sag ' | ' '' ts.0 'Constant(s)' '' tmp2='style="display:none"' call sag ' | |
---|---|---|
No. | Name | Value'
call sag ' |
'i ' | ' ts.i ' | ' a~oleobject~getconstant( ts.i ) end call sag " |
' o=a~methodDir if bBrowser then -- assuming to run under WWW-browser window~status='Analyzing and creating HTML-text for available' o~items 'methods ...' call sag call sag '
' '' a~methodDir~items 'Method[s]' '' call sag ' | ||||
---|---|---|---|---|
No. | Name' call sag ' | Argument[s], Documentation'
call sag ' | ||
' m retType=ot~retType call sag ' | 'choose(retType="VT_VOID", "", retType)'' call sag ' | ' ts.i'' -- call sag ' | ' call sag ' | ' if p_items > 0 then do call sag '( ' call write_arguments_compact ot~params call sag ' )' end if wordpos( ot~doc~string, "n/a (null)") = 0 then do if p_items>0 then call sag ' |
' call sag '' ot~doc~string '' end call sag end end call sag ' |
' Prop_totals=a~getPropertyDir~items + a~putPropertyDir~items + a~naDir~items if bBrowser then -- assuming to run under WWW-browser window~status='Analyzing and creating HTML-text for available' prop_totals 'properties ...' call sag call sag '
' '' prop_totals 'Property[ies]' '' call sag ' | ||||
---|---|---|---|---|
No. | Name' call sag ' | Argument[s], Documentation'
call sag ' | ||
' m retType=ot~retType call sag ' | 'choose(retType="VT_VOID", "", retType)'' -- indicate the put-property by appending the assing operator "=" call sag ' | ' ts.i || choose(ot~invKind=4, "=", "") '' -- call sag ' | ' call sag ' | ' if p_items > 0 then do call sag '( ' call write_arguments_compact ot~params call sag ' )' end if wordpos( ot~doc~string, "n/a (null)") = 0 & \(ot~invKind=4 & getName=ts.i) then do if p_items>0 then call sag ' |
' call sag '' ot~doc~string '' end end call sag end call sag ' |
' o=a~eventDir if bBrowser then -- assuming to run under WWW-browser window~status='Analyzing and creating HTML-text for available' o~items 'events ...' call sag call sag '
' '' o~items 'Event(s)' ''
call sag 'No. | | Name'
call sag ' | Argument[s], Documentation'
call sag ' | ' m
call sag ' | '
call sag ' | ' ts.i''
-- call sag ' | '
call sag ' | '
if p_items > 0 then
do
call sag '( '
call write_arguments_compact ot~params
call sag ' )'
end
if wordpos( ot~doc~string, "n/a (null)") = 0 then
do
if p_items>0 then call sag ' | | '
call sag '' ot~doc~string ''
end
end
call sag
end
call sag " | |
---|
arg #' m 'of' t':' ' | ' choose(o~opt, pp(o~name), o~name) , -- call sag ' | ||||
' choose(o~opt, pp(o~name), o~name) , call sag ' | |||||
#' m':' ' | ' choose(o~opt, '[ ' || o~name || ' ]', o~name) , ' | ' choose(o~in, "in", "") , ' | ' choose(o~out, "/out", "") , ' | ' choose(o~opt, '[ optional ]', "") , ' | ' o~type end call sag ' |