KEMBAR78
Applied DWS2 Programming | PDF | Computer Engineering | Information Technology Management
0% found this document useful (0 votes)
483 views136 pages

Applied DWS2 Programming

This document is a release candidate for a book about Applied DelphiWebScript II Programming. It provides an overview of DWS II, instructions for installation, and describes the basics of DWS II including script syntax and using Delphi objects in scripts. It also outlines the standard DWS II libraries and functions available for strings, math, time, files, GUI elements, and more. The document is still a work in progress, needing proofreading and some additional topics to be filled out. Feedback is welcomed to improve the document.

Uploaded by

Emrah Özcan
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
483 views136 pages

Applied DWS2 Programming

This document is a release candidate for a book about Applied DelphiWebScript II Programming. It provides an overview of DWS II, instructions for installation, and describes the basics of DWS II including script syntax and using Delphi objects in scripts. It also outlines the standard DWS II libraries and functions available for strings, math, time, files, GUI elements, and more. The document is still a work in progress, needing proofreading and some additional topics to be filled out. Feedback is welcomed to improve the document.

Uploaded by

Emrah Özcan
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 136

Applied DelphiWebScript II Programming

DelphiWebScript Community 12th August 2003

Release Candidate 2

Release Candidate 2

to all members of the DWS community

Release Candidate 2

Release Candidate 2

This is Release Candidate 2 of Applied DelphiWebScript II Programming. Please understand that this document still lacks serious proof-reading. Be aware that the main author of the original version of this document is no native English speaker. If you nd grammar mistakes, mistakenly used words, bad style or other bad things, please contact him at mailto:willi@dwscript.com. If you think that a specic topic you can not nd should denitely go into this document, we strongly encourage you to drop us a note. (Use the forum at our sourceforge page!)
A This document was created with MiKTEX and LYX on Windows. Several LTEX packages have been used in order to create this document: framed, eso-pic, color, rotating, array, listings and hyperref.

Date

Version of Document Added HowTos contributed from Yeoh Ray Mond Added HowTo for emulating dynamic arrays

08/12/2003

Bugxed TWindow class Added StringsUnit description

08/11/2003 08/08/2003 Still to do:

Added LeftStr, RightStr and MidStr Changes contributed by Yeoh Ray Mond Release Candidate 1

add explanations to COMConnector Finish section 2.2 -> Explain IInfo A special Thank you goes out to Yeoh Ray Mond for providing lots of corrections and helpful suggestions

Release Candidate 2

Release Candidate 2

Applied DelphiWebScript II Programming aims to provide you with an in-depth coverage of the DWS component, the intentions we had when creating the interpreter, some outlook on future developments and of course it will provide you with the necessary examples and hints for building professional DWS driven applications - regardless if you are developing web applications or old style GUI applications. This document has been brought to you by long standing members of the community and some of the most active DWS developers. We hope that itll answer all questions you possibly might have regarding DWS and that it is able to remove any misconceptions that might have arisen over time. Most probably the name DelphiWebScript itself is already source for such misconceptions, as it implies that DWS is for web scripting only. This is, however, not the case at all. In fact DWS is a Delphi component that takes some script (written in a subset of Delphi), compiles it into an abstract syntax tree and then runs the script. The reason for the WebScript in the name is the ability of DWS to run any kind of input through a so called lter before starting the compile cycle. The lter is responsible for morphing the input into a valid DWS script the compiler expects. Currently one lter ships with the DWS distribution: HTMLFilter. The HTMLFilter expects a text le as input and does nothing else but wrap a print command around the text found in the le. Of course this description is an over simplication, as HTMLFilter allows you to insert DWS scripts within special marked blocks in the text le, but you get the basic idea. Back in the year 2000 (you remember the Internet hype?), Delphi 5 was lacking some convenient way of producing server side scriptable HTML pages. Delphi only featured the well known TPageProducer. One main disadvantage of this component was that the CGI or ISAPI module had to be recompiled every time a change in the application logic (i.e. within the events of the page producer component) was made. DI Hannes Hernler by that time came across the TScript component written by Matthias Ackermann and saw the potential of a modied TScript that could parse native HTML for his web applications. To make a long story short: Matthias Ackermann delivered a modied TScript component and it was agreed to make this component widely available, thus making it open source under the MPL license. By that time it was also decided to rename the component to DWS, as the main future was seen in developing web applications. Since then many things happened: The Internet hype vanished, DWS was re-written from scratch (DWS II) several research projects were made for DWS (Session Server, automatic wrapper generator, Package Connector, Debugger just to name a few) and even DWS3 was started in our CVS repository at sourceforge.

Release Candidate 2

Foreword

Today DWS II is available for Delphi 5, Delphi 6 and Delphi 7 (it shipped with companion CD of Delphi 6 and Delphi 7), Kylix 3 and Borland C++ Builder. DWS would not have been possible without the work of many people from all over the world! So we would like to say a special Thank You to all who have contributed to DWS.

Thanks to...

Andreas Luleich for countless compiler improvements Hannes Hernler for paying the web server bill

Mark Ericksen for IDE Demos, several other tools and improvements in lots of areas. Matthias Ackermann for bringing TScript, DWS and DWS II 1.0 to life! All other contributors (in alphabetical order): Brink, Danie (South Africa) Darling, Jeremy Egorov, Nikita (Russia) Fuchs, Manfred (Germany) Grange, Eric (France) Hariseno, Jagad (Hungary) Krenn, Willibald (Austria) Lind, Martin (Denmark) Listac, John Rheinheimer, Danilo Luiz (Brazil) Riepp, Michael (Germany) Ronzano, Juan Luis (Portugal) Tosik van Leijen, Wilbert (Netherlands) Waldenburg, Martin (Germany) Wilcox, Ken

Release Candidate 2

I.

A Quick Introduction to DWS II

Release Candidate 2

Contents

13
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 15 16 18 19 20 20 23 23 25 28 31 31 34 37 40 41

1. Installation 1.1. Directory Structure . . . . . . . . . . . . . . . . . . . 1.2. Packages . . . . . . . . . . . . . . . . . . . . . . . . 1.2.1. Common Runtime Package: dws2Runtime.dpk 1.2.2. VCL Runtime Package: dws2VCLRuntime.dpk 1.2.3. CLX Runtime Package: dws2CLXRuntime.dpk 1.3. Installation of the Dws2 Core Components . . . . . . . 2. DWS II - the Basics 2.1. SimpleDemo.dpr . . . . . . . . . . . . . . . . . . 2.2. Calling Script Functions from Delphi: Call.dpr . . 2.3. DWS II Language - a Subset of Delphi Pascal . . . 2.3.1. How to Design DWS II Scripts . . . . . . . 2.3.2. DWS II Script - Syntax . . . . . . . . . . . 2.4. Working with Delphi Objects in Scripts: dws2Unit 2.4.1. Constructor and ExternalObject . . . . . . 2.4.2. Simple Method . . . . . . . . . . . . . . . 2.4.3. More Advanced Techniques . . . . . . . .

. . . . . . . . .

. . . . . . . . .

. . . . . . . . .

. . . . . . . . .

. . . . . . . . .

. . . . . . . . .

. . . . . . . . .

. . . . . . . . .

. . . . . . . . .

. . . . . . . . .

. . . . . . . . .

. . . . . . . . .

. . . . . . . . .

. . . . . . . . .

. . . . . . . . .

II. Standard DWS II Library Reference


3. DWS II Standard Libraries 3.0.4. How To Manually Install a DWS II Library . . . . . . . . . 3.1. COM - Connector . . . . . . . . . . . . . . . . . . . . . . . . . . . 3.2. Internal Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . 3.2.1. Maths Functions . . . . . . . . . . . . . . . . . . . . . . . 3.2.1.1. Math Trigonometric Utilities - DWS II Reference 3.2.1.2. Math Float Utilities - DWS II Reference . . . . . 3.2.1.3. Math Random Utilities - DWS II Reference . . . 3.2.1.4. Math Misc. Utilities - DWS II Reference . . . . . 3.2.2. String Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

43
45 45 46 46 47 49 51 53 54 55

Contents 3.2.2.1. String Utilities - DWS II Reference . 3.2.3. Time Functions . . . . . . . . . . . . . . . . . 3.2.3.1. Time Utilities - DWS II Reference . 3.2.4. Variant Functions . . . . . . . . . . . . . . . . 3.2.4.1. Variant Utilities - DWS II Reference 3.2.5. FileFunctions (Component) . . . . . . . . . . 3.2.5.1. File Utilities - DWS II Reference . . 3.2.6. GUI Functions (Component) . . . . . . . . . . 3.2.6.1. GUI Utilities - DWS II Reference . . 3.2.7. Global Variable Functions (Component) . . . . 3.2.7.1. GVar Utilities - DWS II Reference . Strings Unit . . . . . . . . . . . . . . . . . . . . . . . Classes Library . . . . . . . . . . . . . . . . . . . . . Database Libraries (IBX, IBO) . . . . . . . . . . . . . 3.5.1. dws2IBXDataBase, dws2IBODataBase . . . . 3.5.2. dws2IBXDataSrc, dws2IBODataSrc . . . . . . 3.5.3. dws2IBXLib, dws2IBOLib . . . . . . . . . . . Fiber Library . . . . . . . . . . . . . . . . . . . . . . Ini Library . . . . . . . . . . . . . . . . . . . . . . . . MF Library . . . . . . . . . . . . . . . . . . . . . . . 3.8.1. dws2MFLoader . . . . . . . . . . . . . . . . . 3.8.2. Basic . . . . . . . . . . . . . . . . . . . . . . 3.8.2.1. Functions . . . . . . . . . . . . . . 3.8.3. Connection . . . . . . . . . . . . . . . . . . . 3.8.3.1. Functions . . . . . . . . . . . . . . 3.8.4. Dialog . . . . . . . . . . . . . . . . . . . . . . 3.8.4.1. Functions . . . . . . . . . . . . . . 3.8.5. File . . . . . . . . . . . . . . . . . . . . . . . 3.8.5.1. Constants . . . . . . . . . . . . . . 3.8.5.2. Functions . . . . . . . . . . . . . . 3.8.6. Info . . . . . . . . . . . . . . . . . . . . . . . 3.8.6.1. Constants . . . . . . . . . . . . . . 3.8.6.2. Functions . . . . . . . . . . . . . . 3.8.7. Registry . . . . . . . . . . . . . . . . . . . . . 3.8.7.1. Constants . . . . . . . . . . . . . . 3.8.7.2. Functions . . . . . . . . . . . . . . 3.8.8. Shell . . . . . . . . . . . . . . . . . . . . . . 3.8.8.1. Functions . . . . . . . . . . . . . . 3.8.9. String . . . . . . . . . . . . . . . . . . . . . . 3.8.9.1. Constants . . . . . . . . . . . . . . 3.8.9.2. Functions . . . . . . . . . . . . . . 3.8.10. System . . . . . . . . . . . . . . . . . . . . . 3.8.10.1. Constants . . . . . . . . . . . . . . 3.8.10.2. Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57 62 63 67 69 71 73 76 77 79 81 82 83 87 87 87 87 92 93 94 95 95 95 95 95 95 95 96 96 96 97 97 98 99 99 99 100 100 100 100 100 101 101 104

3.3. 3.4. 3.5.

3.6. 3.7. 3.8.

10

Release Candidate 2

Contents 3.8.11. Window . . . . . . . 3.8.11.1. Functions 3.8.12. dws2MFZipLib . . . 3.8.12.1. Constants 3.8.12.2. Classes . . 3.9. Symbols Library . . . . . . 3.10. Web Library . . . . . . . . . 3.10.1. dws2PageProducer . 3.10.2. dws2PageLoader . . 3.10.3. dws2SessionLib . . 3.10.4. dws2WebLib . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 105 105 106 106 107 109 110 111 111 111 113

4. Non DWS II Standard Libraries 117 4.1. ADO Library . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 117 4.2. DB Library . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 117 4.3. SMTP Library (D5, D6 only) . . . . . . . . . . . . . . . . . . . . . . . . . . . 117

III. Advanced Topics


5. DWS II Tools

Release Candidate 2

119
121 123 123 123 123 124 125 125 125 125 125 125 125 126 127

6. Creating Web Applications Using DWS II 2.0 6.1. Installation of the ISAPI Demo . . . . . . . . 6.1.1. Using IIS . . . . . . . . . . . . . . . 6.1.2. Using Apache 2.0 . . . . . . . . . . . 6.2. Other demos.. . . . . . . . . . . . . . . . . .

. . . .

. . . .

. . . .

. . . .

. . . .

. . . .

. . . .

. . . .

. . . .

. . . .

. . . .

. . . .

. . . .

. . . .

. . . .

. . . .

. . . .

. . . .

7. How-To 7.1. Working with Objects . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7.1.1. In Delphi, Get the Reference to a Delphi Object that is Wrapped by a Script Object . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7.2. Working with DWS2Unit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7.2.1. In DWS, Use Functions/Procedures/Objects Dened in other Dws2Units 7.3. Working with Scripts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7.3.1. In DWS, Emulate Dynamic Arrays . . . . . . . . . . . . . . . . . . . . 7.3.2. In Delphi, Detect if a Variable is Used During the Running of the Script 8. Appendices

11

Contents

12

Release Candidate 2

Part I.

A Quick Introduction to DWS II

Release Candidate 2

13

Release Candidate 2

This chapter shows how to set up your development environment and will discuss the modules DWS II is broken into. Note that the information presented here is subject to change in future releases. It is therefore a good practice, to read the Readme le that comes with every DWS distribution package. This chapter wont cover the automatic installer that might have shipped with DWS II. Instead itll explain the modules we have in our CVS repository and how to install these modules by hand. Some of the modules are not included in the DWS II distribution package because of their unnished state.

1.1. Directory Structure

Figure 1.1.: DWS root in CVS Browsing our CVS repository reveals the module listing from above. Although this document deals with DWS II only, well briey go over all non-dws2 modules too. The SampleWebApps, connectors, dws3 and tools modules are deprecated - respectively currently not actively maintained. SampleWebApps was meant to hold a few sample web applications that were developed using DWS. Unfortunately this goal was never reached. The

Release Candidate 2

1. Installation

15

1. Installation connectors module is a reminiscent of some feature we had envisioned for DWS. Today the COM connector - which is the one and only connector that got implemented - resides in the dws2/Source directory. In the dws1 module you can nd the rst version of DWS that lacked OOP, but had support for function overloading implemented. This module is not actively maintained anymore, as is the dws16 module, that contains the 1.6 release of DWS. (This release was checked in to a separate module to ease checkout for developers who are not familiar with CVS tags or branches.) DWS3 holds a DWS version that should have become the next release after DWS II 1.0. Its based on the DWS II 1.0 source code but was enhanced to allow concurrent execution of the same TProgram object. To put it differently, DWS3 is thread safe. Please keep in mind that DWS3 is not production quality and more or less experimental. The DWS3 module also contained some preliminary version of the PackageConnector1 . Currently there is no development going on in the DWS3 module. Finally, the tools and wrapper modules contain some deprecated code. Today, the development takes place in the dws2 and dws2tools modules. Figure 1.2 on the facing page shows the directory tree of the checked out dws2 module. The most important subdirectory in the dws2 module is probably the Source directory. This directory contains the complete Delphi source code for the core DWS II components. If you want to use DWS II in your applications, you have to include this directory in your Delphi (or Kylix) library path! The various Delphi<version> and Kylix<version> subdirectories contain the runtime and design-time packages for DWS II. Obviously a good starting point to explore the power of DWS II is the Demos subdirectory. Please note that youll need to have synedit (a recent snapshot!) installed if you want to try them all out. Later on well examine the demos anyway, as they show how to use DWS. Thereafter well briey explore the supplied libraries and nally well cover the dws2tools module. You can see the directory structure of the dws2tools module on page 22.

1.2. Packages
DelphiWebScript II is separated into several runtime and design-time packages. This is not only demanded by Borland, but also necessary for developers who want to ship their projects split into runtime packages2 . Basically DWS II is separated into:
For the interested reader: Due to some difculties with the DWS3 type system and the lack of interest in the DWS3 module itself, the PackageConnector was nally canned. The over-all idea behind the package connector was to be able to use native Delphi classes in any DWS script without the need to create wrapper code. This was achieved by letting the Delphi compiler do the wrapping - in other words: Let Delphi compile the code into runtime packages and call the methods found in the resulting runtime package. The implementation got never beyond some proof of concept code. If you want to see some examples that already worked you might visit http://www.countsandbarons.com/spass/SpassFrames.htm 2 We strongly suggest that readers who are not familiar with the package concept of Delphi should consult their favourite Delphi book and read up on that topic. If anyone is interested in the name mangling schema of the Delphi/Kylix compilers (versions 5 & 6 - Delphi 7 adds something new if the mangled string is longer than 255 chars): http://www.countsandbarons. com/spass/art/packages_en.htm
1

16

Release Candidate 2

1.2. Packages

Figure 1.2.: dws2 module, directory layout 17

Release Candidate 2

1. Installation One design-time package, that is only needed by developers working with DWS II in the Delphi IDE,

one VCL runtime package, that depends on the general runtime package and provides functions that rely on the VCL

and last but not least one CLX runtime package, that depends on the general runtime package and provides the same functionality found in the VCL runtime package.

Depending on the Delphi version you have, you can not compile all runtime packages mentioned above. Delphi 5 (and all versions below) does not know anything about the CLX, so its senseless trying to compile the CLX runtime. Kylix on the other hand does not ship with the VisualComponentLibrary, so you cant compile the VCL runtime. Note, that the Delphi Personal editions do not ship with CLX and might not even ship with all VCL classes, so there could be trouble compiling the VCL runtime. N OTE

Most of the libraries that ship with DWS II are not Linux compatible and do not have the design-time/runtime separation. Thats because they only register one component in the Delphi IDE and do not depend on any Delphi IDE runtime package for IDE integration.

1.2.1. Common Runtime Package: dws2Runtime.dpk


Starting with the dws2Runtime package, we want to cover the contents of the packages and mention some versioning problems that might arise when using runtime packages. Until Delphi 5 runtime packages had to be named along the pattern: <my-Product>50.dpk for Delphi 5, <my-Product>40.dpk for Delphi 4 and so on. This was necessary so that versions of the same runtime package compiled with different versions of Delphi could reside on the same computer. Borland decided to improve upon this situation and from Kylix 1 / Delphi 6 on developers should use the LIBSUFFIX option to indicate the Delphi version a package was compiled with.

18

Release Candidate 2

one general runtime package, that contains all non-GUI DWS II classes (all the core classes fall in this category),

1.2. Packages The DWS community uses following convention for the LIBSUFFIX option: Delphi 6: 60 Delphi X: X0 C ONVENTION Kylix X: X0

Beginning with DWS II 2.0 well also set the LIBVERSION option: DWS II 2.0: 20 DWS II X.Y: XY

The Delphi 5 packages, which have no support for the options mentioned above, will be named like dws2Runtime50_<DWSIIVersion>.dpk (e.g. dws2Runtime50_20.dpk).

Following components are located in the common runtime package: 1. TDelphiWebScriptII 2. Tdws2HtmlFilter 3. Tdws2SimpleDebugger 4. Tdws2FileFunctions 5. Tdws2GlobalVarsFunctions 6. Tdws2StringResultType 7. Tdws2Unit 8. Tdws2HTMLUnit, 9. Tdws2StringsUnit

1.2.2. VCL Runtime Package: dws2VCLRuntime.dpk


As already mentioned, all VCL dependant classes are located in the VCL runtime package. This package provides following components: 1. dws2ComConnector 2. dws2VclGuiFunctions

Release Candidate 2

19

1. Installation You can only use these components when developing a VCL based application! Delphi will automatically hide all dws2 VCL based components if the currently active project is CLX based. H INT

1.2.3. CLX Runtime Package: dws2CLXRuntime.dpk

The CLX runtime package is mostly considered for cross-platform development. Therefore no DWS II COM support was included in this package. Currently, the only component that is contained in dws2CLXRuntime is the dws2ClxGuiFunctions component, that can be considered as a 1:1 copy of the VCL GUI functions component. Of course dws2ClxGuiFunctions bind to CLX instead of the VCL. ATTENTION

It is not possible to use the COM connector in CLX based projects.

1.3. Installation of the Dws2 Core Components


Installation of DWS II by hand is pretty straight forward. First, locate the Delphi subdirectory matching your Delphi version in the dws2 directory. Load the dws2Runtime package and compile it. Next load the other runtime packages (VCL,CLX) and compile again. Now you are ready to install the design-time package: Load the dcldws2.dpk package and install.

20

Release Candidate 2

1.3. Installation of the Dws2 Core Components Do not forget to include the dws2/Source directory in your library path, so that Delphi can nd all dws2 source les. If you are using Linux, you might want to modify your LD_LIBRARY_PATH variable to point to the directory where all bpl*.so.* les were put by the Delphi compiler. If it might happen, that you have to convert Delphi 5 projects that are using DWS to Delphi 6 (or 7), you should modify the Delphi.upg le found in your Delphi 6 (Delphi 7) bin directory and append following lines: dws2Runtime50_<Version>=dws2Runtime dws2VCLRuntime50_<Version>=dws2VCLRuntime dws2CLXRuntime50_<Version>=dws2CLXRuntime dcldws250=dcldws2

Your component palette should now have a tab labeled DWS2. By selecting this tab, you should see all components from gure 1.4 on the following page. The components background color indicates the type of the component: C ONVENTION Yellow means internal functions (usually fast) Blue stands for debugger Orange means lter Gray indicates result types and TDelphiWebScriptII Pink stands for dws2units

Congratulations: By now you should have a working DWS2 installation running. Using this as a basis, well introduce different DWS II libraries and tools in the next few chapters. But before doing so, well examine the basic DWS II capabilities by looking at a few examples that run without additional libraries.

Release Candidate 2

H INT

21

1. Installation

Figure 1.3.: dws2tools module - directory tree

Figure 1.4.: dws2 core (above: VCL; below: CLX)

22

Release Candidate 2

Weve decided to cover a few easy examples that ship with DWS right here, so that you get an idea of what can be done with DWS.

2.1. SimpleDemo.dpr

In the dws2/Demos/Simple directory youll nd the SimpleDemo that demonstrates the minimum requirements DWS II needs in oder to compile and run scripts. If you open the Delphi project, youll see a main form that has two memos, one button and a TDelphiWebScript2 component dropped onto it. If you press F9 and then the Compile&Execute button, youll get the output seen in gure 2.1. By looking at the event handler source code of the TButton youll see the minimum code that is needed for embedding the DWS II component. Listing 2.1: SimpleDemo EventHandler code

uses dws2Exprs , d ws 2 C o m pi l e r ; p r o c e d u r e TFSimpleDemo . BNCompileAndExecuteClick ( S e n d e r : TObject ) ; var x : Integer ; P r o g : TProgram ; begin / / C o m p i l e t h e s c r i p t program P r o g : = D e l p h i W e b S c r i p t I I 1 . Compile ( MSource . T e x t ) ; / / D i s p l a y e r r o r m e s s a g e s ( i f any ) i f P r o g . Msgs . H a s C o m p i l e r E r r o r s t h e n f o r x : = 0 t o P r o g . Msgs . Count 1 do ShowMessage ( P r o g . Msgs [ x ] . A s I n f o ) ; / / E x e c u t e t h e s c r i p t program Prog . Execute ; / / Display the output MResult . T e x t : = T d w s 2 D e f a u l t R e s u l t ( P r o g . R e s u l t ) . T e x t ; / / D i s p l a y e r r o r m e s s a g e s ( i f any ) f o r x : = 0 t o P r o g . Msgs . Count 1 do ShowMessage ( P r o g . Msgs [ x ] . A s I n f o ) ;

10

12

14

16

18

20

22

Release Candidate 2

2. DWS II - the Basics

23

2. DWS II - the Basics

Figure 2.1.: SimpleDemo Output

24

Release Candidate 2

2.2. Calling Script Functions from Delphi: Call.dpr


24

end ;

H INT

This example does not use any kind of lter, nor a custom result type. If no custom result type is applied to the DWS II component, TProgram.Result always gives back a Tdws2DefaultResult object! You can apply a custom DWS II result type by dropping e.g. the dws2StringResultType component onto the form that already contains a TDelphiWebScriptII component. Do not forget to set the Conguration.ResultType property of the TDelphiWebScriptII component to the newly added result type component! If you drop a lter component onto a form dws2Compiler automatically gets added to the uses clause, so you only have to add the dws2Exprs unit. To enable the lter, you have to set the Conguration.Filter property of the TDelphiWebScriptII component to the newly added lter. A lter / result type can only be assigned to one TDelphiWebScriptII component at a time!

2.2. Calling Script Functions from Delphi: Call.dpr


Weve now seen how to compile and execute a complete DWS script. Often, however, we only want to call a function in the script and do not want to execute the whole script. Indeed, it could be that the script does not have a main program but only functions and procedures dened! DWS offers you the exibility you need: Its no problem calling a script function from Delphi code. To see how this works, load the Call demo that ships with DWS II 2.0. Figure 2.2 on the next page shows the design-time view of the demos main form. Its easy to see that the script on the right side of the form lacks a main program. It consists only of four functions/procedures and a type declaration. The reason we need the GUI component here is the call to ShowMessage in procedure Test1. Without dropping the GUI component onto the form, DWS II would not be able to compile the

Release Candidate 2

Several things in this example are worth to mention: If you look at the implementations uses clause, youll notice that two units (dws2Exprs and dws2Compiler) were included by hand. We need to include dws2Exprs because it denes the TProgram class the DWS II compiler returns. Dws2Compiler is necessary because of the Tdws2DefaultResult cast. Also note the pattern we used to compile and execute the script! First we compile, then we check for errors and only if everything worked out OK we call the execute method of the script. Please keep in mind that a script could cause different runtime errors! So we check for them too.

25

2. DWS II - the Basics

Figure 2.2.: Call Demo - Design-time

26

Release Candidate 2

2.2. Calling Script Functions from Delphi: Call.dpr script! For a complete list of functions dened by the GUI component please refer to to chapter 3. So, whats necessary to call a script procedure?

10

p r o c e d u r e TForm1 . B u t t o n 1 C l i c k ( S e n d e r : T O b j e c t ) ; var p r o g : TProgram ; begin p r o g : = D e l p h i W e b S c r i p t I I . Compile ( Memo1 . T e x t ) ; prog . BeginProgram ; p r o g . I n f o . Func [ Test1 ] . C a l l ( [ E d i t 1 . T e x t ] ) ; p r o g . EndProgram ; p r o g . Free ; end ;

As you can see, its pretty easy to invoke a script procedure! First, the script is compiled into a TProgram. As a next step the BeginProgram function is called. Its utterly important that you call this method before trying to invoke a script function! You also have to call EndProgram before destroying the TProgram object. Please keep in mind that the source found in listing 2.2 is nowhere near production quality! There are several points that smell: N OTE No try-nally around the creation of the TProgram object and the call to free No check for DWS II compile time errors

Before going into details about the invocation call itself, lets look at the Delphi source code necessary to call the Test4 script function: Listing 2.3: CallDemo: calling Test4

p r o c e d u r e TForm1 . B u t t o n 4 C l i c k ( S e n d e r : T O b j e c t ) ; var p r o g : TProgram ; funcInf , r e s u l t I n f : IInfo ; begin

Release Candidate 2

Listing 2.2: CallDemo: calling Test1

27

2. DWS II - the Basics


p r o g : = D e l p h i W e b S c r i p t I I . Compile ( Memo1 . T e x t ) ; prog . BeginProgram ; f u n c I n f : = p r o g . I n f o . Func [ Test4 ] ; f u n c I n f . P a r a m e t e r [ Struct ] . Member [ a ] . E l e m e n t ( [ 0 ] ) . Value : = S p i n E d i t 1 . Value ; f u n c I n f . P a r a m e t e r [ Struct ] . Member [ a ] . E l e m e n t ( [ 1 ] ) . Value : = S p i n E d i t 2 . Value ; f u n c I n f . P a r a m e t e r [ Struct ] . Member [ b ] . V a l u e : = S p i n E d i t 3 . Value ; r e s u l t I n f : = funcInf . Call ; S p i n E d i t 4 . V a l u e : = r e s u l t I n f . Member [ a ] . E l e m e n t ( [ 0 ] ) . Value ; S p i n E d i t 5 . V a l u e : = r e s u l t I n f . Member [ a ] . E l e m e n t ( [ 1 ] ) . Value ; S p i n E d i t 6 . V a l u e : = r e s u l t I n f . Member [ b ] . V a l u e ; p r o g . EndProgram ; p r o g . Free ; end ;

10

12

14

16

18

Clearly, Calling Test4 demands more work to be done by the programmer.

H INT

Just in case you wonder where TStruct was dened, have a look at the script in gure 2.2 on page 26!

ToDo: Explain IInfo here!

2.3. DWS II Language - a Subset of Delphi Pascal

By now weve only covered the Delphi - side of DWS II. This section will give you an idea of how the Pascal subset of DWS II looks like. The syntax of DWS II script is similar to Delphi, making the learning curve not very steep. Perhaps we should start with a list of what is not supported by DWS II.

28

Release Candidate 2

2.3. DWS II Language - a Subset of Delphi Pascal Following Delphi language features are NOT supported by DWS II sets

pointer interfaces function overloading

goto, label, public, protected, private, published ATTENTION other low level Delphi instructions (packed, in/out, cdecl/.., etc..) call DLL functions from script directly save a compiled DWS II script to a lea
a

Lots of developers have already demanded such a feature. Therefore well briey discuss why we will not implement it. First, DWS II lets you dene custom lters that enables you to encrypt your scripts. Second, DWS II has a very fast compiler. Its no performance problem to compile scripts instead of loading a binary representation that has to be de-serialized. Third, DWS II very strongly depends on libraries providing functions that can be called. When loading a binary representation of a DWS II script we would have to make sure all libraries are compiled into the application that loads and wants to execute the script. When compiling the script this is automatically done by the DWS II compiler. Fourth, it would be tremendous work without gaining any signicant feature: If you want something compiled into a binary representation for speed reasons, USE DELPHI!

Perhaps its more important to say what actually IS supported (Bold printed Items are not supported by Delphi):

Flow-Control: If-then-else For, While, Repeat-until Break, Continue Case Supports non-ordinal data types

Release Candidate 2

with clause

29

2. DWS II - the Basics

Try-except, Try-nally Functions, Procedures Recursion Mutual Recursion Complex Return Types Default Parameters Classes Fields Methods Virtual Static Properties Array Properties Default Properties Exceptions native Delphi Exceptions (are mapped to EDelphi) DWS script Exceptions Data types Basic Data types: String Integer Boolean Float (= Double) Variant Every Connector may dene other basic Data types (e.g.: COM Connector introduces COMVariant.)

Structured Data types: Records Arrays, Dynamic Arrays Enumerations

30

Release Candidate 2

2.3. DWS II Language - a Subset of Delphi Pascal

Compiler Constant Folding (and/or other custom optimizations) All Variables are initialized Supports declarations anywhere in script ....

2.3.1. How to Design DWS II Scripts

In order to get the maximum DWS performance, you should know how to design your scripts. We nd it very important that you stick to the design rules given in this document. 1. Scripts should be: a) As short as possible

b) Must not contain calculation intense algorithms c) Do not excessively use loops - especially with lots of iterations 2. Outsource as many functions as possible to Delphi and call them. (Use the dws2Unit component!) 3. If possible, cache your compiled TPrograms - do not compile every time again.

DWS II has an option for optimization when compiling the script. The main work done by the optimizer is constant folding. Note, however, that only internal functions can take advantage of this by default. All other functions have to support this explicitly. Internal functions are so to speak built into the TDelphiWebScriptII component. So most internal functions are always available. You can nd a list of all internal functions in section 3.2 on page 46.

2.3.2. DWS II Script - Syntax


The main difference of the syntax used by DWS II and Delphi is that DWS II allows you to dene types/variables almost everywhere in script. This ability is necessary for working with HTML les, as there is no such structure present that we nd in Delphi units or programs.

H INT

Release Candidate 2

31

2. DWS II - the Basics This has one important implication, namely DWS II does not like to have types dened where you would dene them in Delphi: After the function / procedure header but before the begin keyword of the functions / procedures implementation part. See listing 2.4 for an example.

All listings within a shadowbox are considered to be DWS II scripts. All other listings contain Delphi code.

Listing 2.4: DWSIISyntax: Differences to Delphi

procedure t e s t ; / / f o r c o m p a t i b i l i t y r e a s o n s you can d e c l a r e / / v a r i a b l e s here var x : v a r i a n t ; procedure y ; / / d e c l a r e n e s t e d p r o c e d u r e ERROR begin / / DWSII d o e s n o t a l l o w you t o d e f i n e / / a nested procedure here ! ! end ; begin p r o c e d u r e z ; / / ok var a: float ; b: integer ; begin / / n o r m a l DWSII s y n t a x : d e c l a r e e v e r y t h i n g / / you n e e d w i t h i n b e g i n / end p a i r s var c : b o o l e a n ; end ; end ;

10

12

14

16

18

20

22

It is highly recommended that you load the Basics demo and experiment with the available Demos yourself! For convenience well reprint here the NestedDeclarations example. It demonstrates the lifetime of a declaration.

32

Release Candidate 2

H INT

2.3. DWS II Language - a Subset of Delphi Pascal You might have noticed by now that there is no explicit main program in DWS II scripts. This observation is partly correct. Ideally you should think that the whole script you write is encapsulated between a begin end pair! As a consequence the whole script is the main program. Another important twist comes in here: When dening variables or types within a begin - end pair, you have to begin the declaration every time with the appropriate keyword! So the following script is not valid and will produce a compile time error. //[...] begin var x: integer; y: bool; // error! end; //[...]

Below youll nd the source of the NestedDeclarations example. Please note how x and s are dened the rst time: Every declaration starts with the var keyword. (Following declaration would also have been valid: var x, s: Integer;.) Listing 2.5: DWSIISyntax: Nested Declaration

10

12

14

16

18

20

{ S p e c i a l DWSII S y n t a x : It s p o s s i b l e to declare v a r i a b l e s everywhere in t h e s c r i p t c o d e . The d e c l a r a t i o n i s v a l i d i n s i d e t h e a c t i v e b l o c k ( a f t e r t h e d e c l a r a t i o n ) and i t s subb l o c k s . } var x : I n t e g e r ; var s : I n t e g e r ; / / you n e e d t h e var h e r e ! ! f o r x : = 0 t o 1 0 do begin var s : s t r i n g ; / / o v e r r i d e s p r e v i o u s d e c l a r a t i o n / / of " s " ( only i n s i d e t h i s loop ) / / s now a STRING s : = IntToStr ( x ) ; PrintLn ( s ) ; end ; f o r x : = 0 t o 1 0 do begin var s : F l o a t ; / / o v e r r i d e s p r e v i o u s d e c l a r a t i o n / / of " s " ( only i n s i d e t h i s loop )

Release Candidate 2

H INT

33

2. DWS II - the Basics


22

24

28

30

We recommend that you look through all examples the Basic demo provides.

2.4. Working with Delphi Objects in Scripts: dws2Unit


As a last introducery topic, well briey cover the mechanisms DWS II uses to work with Delphi objects. Well discuss the examples found in the Basic demo here. The dws2Unit component is a cornerstone in DWS II: Its the link between native, compiled Delphi code and DWS II scripts. As a consequence its therefore important to know how to work with this component. Although dws2Unit made it somewhat easier to create wrapper code for DWS II, its still a bit cumbersome to work with it. In future, however, there will be some improvement to this situation as there is a dws2UnitEditor in development. (You can nd the sources in the dws2tools module).

Figure 2.3 on the facing page shows all types and functions that are dened in the dws2Unit component of the Basic demo. Modifying the state of a native Delphi object in DWS II script is a very common task. Unlike .NET and Java, Delphi does not offer reection over all types. As you might know, only published parts of a class declaration offer meta-data in Delphi. DWS II therefore needs your help to gure out what methods, elds and properties a Delphi class/object exposes.1 In the following chapters well refer to this process of providing the information as writing wrapper code. If you open the Using Delphi in DWS -> Dws2AccessInDelphi.dws script in the Basic demo, you should see following source:
1

Delphi runtime packages offer far more information about the members they contain. Unfortunately its not possible to determine the return type of a method/function found in a runtime package. Therefore even if it would be possible to call functions in runtime packages, one would have to provide the complete interface declaration of the functions one wants to call.

34

N OTE

Release Candidate 2

26

/ / s now a FLOAT ! s : = Sqrt ( x ) ; PrintLn ( s ) ; end ; f o r x : = 0 t o 1 0 do begin s : = Round ( Sqr ( x ) ) ; / / No r e d e c l a r a t i o n o f " s " s o / / the i n i t i a l d e c l a r a t i o n i s used PrintLn ( s ) ; end ;

2.4. Working with Delphi Objects in Scripts: dws2Unit

Figure 2.3.: Object TreeView of the dws2Unit component found in Basic demo

Release Candidate 2

35

2. DWS II - the Basics Listing 2.6: Working with Delphi objects in DWSII: TWindow

D e m o n s t r a t e s how t o c a l l m e t h o d s f r o m n a t i v e D e l p h i c o d e and how t o a c c e s s t h e d a t a s t r u c t u r e s o f DWS . Have a l o o k a t t h e D e l p h i s o u r c e c o d e o f t h e DWSII c l a s s " TWindow " ! } var w : TWindow ; var i , j , k : i n t e g e r ;

10

12

w : = TWindow . C r e a t e ( 1 0 , 1 0 , Hello World ) ; f o r i : = 1 0 t o 1 0 0 do begin Pause ( 1 0 ) ; / / Sleep w. S e t P o s i t i o n ( i , i ) ; RedrawDwsDemo ; end ;

14

16

18

20

22

24

26

var p : TWindowParams ; t y p e t e s t = a r r a y [ 1 . . 2 ] o f r e c o r d a , b : i n t e g e r end ; var t : T e s t ; p . Left := 200; p . Top : = 2 0 0 ; p . Width : = 3 0 0 ; p . Height : = 5 0 ; p . C a p t i o n : = ; w. SetParams ( p ) ; w. UseVarParamTest ; var v : TWindow ; v : = TWindow (w . N e w I n s t a n c e ) ; Pause (3000) ;

28

30

32

34

36

If you compile and run the demo, you should see three windows created: At rst a little window that moves from top left 100 steps to bottom right. This is done by the for loop starting at line 14. If the loop has completed, the script will create two windows and assign different captions and positions to them.

36

Release Candidate 2

2.4. Working with Delphi Objects in Scripts: dws2Unit If you look at the script, youll notice that there is no call to a destructor of any of the objects created. If you look at gure 2.4 on the next page, youll see that the TWindow class does have a destructor dened. So whats going on here? The answer is pretty simple: DWS II 2.x features Garbage Collection! You do not need to call any destructor in a DWS II script!

ATTENTION

H INT

Its important to realize that a type that can be used in a DWS II script is NOT the native type dened by Delphi - even if the DWS II type has the same name as the Delphi type and tries to provide the same interface as the Delphi type. Everything that you can use in a DWS II script is some wrapper around some native code. The COM connector might be - partly - an exception to this rule.

To fully understand the script from listing 2.6, we must have a look at the denitions and the wrapper code provided by the dws2Unit component for TWindow. See gure 2.4 on the following page for the interface denition of the TWindow class.

2.4.1. Constructor and ExternalObject


Lets start dissecting the example and begin with line 12, where the TWindow constructor gets called the rst time. Figure 2.5 on page 39 shows a screen shot of the Object Inspectors settings for TWindows constructor. Most notably is the OnAssignExternalObject event. Listing 2.7 shows the code behind that event. Listing 2.7: Working with Delphi objects in DWSII: TWindow Constructor

p r o c e d u r e TFDwsDemo . dws2UnitClassesTWindowConstructorsCreate A s s i g n E x t e r n a l O b j e c t ( I n f o : T P r o g r a m I n f o ; var E x t O b j e c t : TObject ) ; begin E x t O b j e c t : = TFTest . C r e a t e ( n i l ) ;

Release Candidate 2

37

2. DWS II - the Basics

Figure 2.4.: Object TreeView of the TWindow class dened by dws2Unit

38

Release Candidate 2

2.4. Working with Delphi Objects in Scripts: dws2Unit

Figure 2.5.: Object Inspector: TWindow Constructor

Release Candidate 2

39

2. DWS II - the Basics


6

T F T e s t ( E x t O b j e c t ) . Show ; end ;

As you can see, the ExtObject parameter is declared using the var directive. This indicates that ExtObject can already have a value assigned when entering OnAssignExternalObject! (Otherwise we would have used the out directive.) There is only one case where this can happen: If you call a constructor via Info.Vars[TMyClass].GetConstructor(Create, delphiObject).Call.Value, OnAssignExternalObject gets called with ExtObject assigned to delphiObject. The most important part of this listing is found in line 5. In this line a Delphi object gets created and assigned to the ExtObject variable. Its important that you understand what function the ExtObject fullls! Remember: We are writing wrapper code here. In other words, we have to create the glue that is necessary for manipulating native Delphi objects. The ExtObject hereby holds a reference to the native Delphi object we want to control within the DWS II script. You have to create it in the code that implements the OnAssignExternalObject event and you have to destroy it later in a destructor. (The destructor gets automatically called by DWS II) Any method you dene and implement later for your DWS II class will get exactly the same ExtObject you created here passed in as function parameter!

The dws2Unit component offers a feature called Instances that is useful for wrapping variables / properties if they contain / return an object. The Using Delphi in DWS -> Tdws2UnitVariablesAutoinstantiate.dws script shows how to use that feature. Basically it allows you to assign the ExtObject on the rst read operation of the instance unit variable.

2.4.2. Simple Method


The rst real method call in listing 2.6 can be found in line 17. Listing 2.8: Working with Delphi objects in DWSII: TWindow SetPosition

40

H INT

Release Candidate 2

ATTENTION

2.4. Working with Delphi Objects in Scripts: dws2Unit


2

As you can see in gure 2.4 on page 38, this method has two parameters: Left and Top. The TWindow class itself also has two members (elds) named Left and Top. The code in listing 2.8 does nothing else, than assign the values of the methods parameters to the internal elds. (Lines 4 and 5.) Line 6 should look somewhat familiar, if youve already read section 2.2 on page 25. To put it in a nutshell: The Update method of TWindow gets called. Update is very interesting to us, because its there, where the linking between DWS II Script Class and native Delphi class happens: Listing 2.9: Working with Delphi objects in DWSII: TWindow Update

Release Candidate 2

p r o c e d u r e TFDwsDemo . dws2UnitClassesTWindowMethodsSetPositionEval ( Info : TProgramInfo ; ExtObject : TObject ) ; begin I n f o . V a r s [ Self ] . Member [ Left ] . V a l u e : = I n f o [ Left ] ; I n f o . V a r s [ Self ] . Member [ Top ] . V a l u e : = I n f o [ Top ] ; I n f o . Func [ Update ] . C a l l ; end ;

Why not Info. Vars[Self] .Func[Update] ..?! -ASK-

p r o c e d u r e TFDwsDemo . d w s 2 U n i t C l a s s e s T W i n d o w M e t h o d s U p d a t e E v a l ( I n f o : TProgramInfo ; ExtObject : TObject ) ; begin T F T e s t ( E x t O b j e c t ) . L e f t : = I n f o [ Left ] ; T F T e s t ( E x t O b j e c t ) . Top : = I n f o [ Top ] ; T F T e s t ( E x t O b j e c t ) . Width : = I n f o [ Width ] ; T F T e s t ( E x t O b j e c t ) . H e i g h t : = I n f o [ Height ] ; end ;

2.4.3. More Advanced Techniques


Another common situation is that your script functions get a script object (say a TSomeScriptObj) as parameter. In the OnEval event, however, you need to modify the underlying native Delphi object. So how do you get the native Delphi Object? Listing 2.10 shows you how to do that. Listing 2.10: Advanced Techniques: Get ScriptObject in OnEval
{ D e c l a r a t i o n o f t h e s c r i p t procedure : procedure ( SomeObject : TSomeScriptObj )

41

2. DWS II - the Basics


2

10

12

14

Here is the declaration of the IScriptObj interface that represents a DWS II script object: Listing 2.11: Advanced Techniques: IScriptObj denition
IScriptObj = interface [ {8D534D1E-4C6B-11D5-8DCB-0000216D9E86} ] f u n c t i o n GetClassSym : T C l a s s S y m b o l ; f u n c t i o n G e t D a t a : TData ; p r o c e d u r e S e t D a t a ( Dat : TData ) ; function G e t E x t e r n a l O b j e c t : TObject ; procedure S e t E x t e r n a l O b j e c t ( Value : TObject ) ; p r o p e r t y ClassSym : T C l a s s S y m b o l read GetClassSym ; p r o p e r t y D a t a : TData read G e t D a t a w r i t e S e t D a t a ; p r o p e r t y E x t e r n a l O b j e c t : T O b j e c t read G e t E x t e r n a l O b j e c t write SetExternalObject ; end ;

10

Other advanced topics: If you want to know, how you can call a constructor of a script class and what to return, look at the NewInstance method of TWindow. There are plenty of other examples available in the basic demo - so have a look at them!

42

Release Candidate 2

Note : TSomeScriptObj i s a s c r i p t c l a s s t h a t has a TSomeObject Delphi o b j e c t a s s i g n e d . . I t s a wrapper a r o u n d T S o m e O b j e c t i n o t h e r words . } var ScriptObj : IScriptObj ; N a t i v e O b j e c t : TSomeObject ; begin / / get the s c r i p t object S c r i p t O b j : = I S c r i p t O b j ( IUnknown ( I n f o [ SomeObject ] ) ) ; i f S c r i p t O b j = n i l then NativeObject : = nil else / / get the native Object N a t i v e O b j e c t : = TSomeObject ( S c r i p t O b j . E x t e r n a l O b j e c t ) ; end

Part II.

Standard DWS II Library Reference

Release Candidate 2

43

Release Candidate 2

The main part of Applied DWS II Programming is the documentation of the libraries that ship with DWS II. Consider the information found here as standard. Figure 3.1 shows a screen shot of the DWS2 tab of the Delphi component palette with the DWS II Common Libraries installed. If you want to implement a library for DWS, please search this chapter for libraries already providing a similar service and consider the API they provide as must implement. (Note: Before raising some sort of ENotImplemented exceptions in your library, skip the method alltogether - even if this method is demanded by the standard.) For example: If you want to implement a new database connectivity library for - say - SAP DB, then look at the DB libraries found here. They dene the minimum subset of functions and methods your library has to provide in oder to be DWS II Standard Library Compliant! Note, that only compliant libraries will be included in the main DWS II release package in future.

3.0.4. How To Manually Install a DWS II Library


Installing a DWS II Library by hand is fairly easy. Just select File->Open Project (*.dpk as le type) in the Delphi main menu. Delphi now shows an open le dialog box. Browse to your DWS II installation directory and double click on the Libraries subdirectory. The open le dialog now shows you the contents of the dws2\Libraries directory. Search for a subdirectory according to your Delphi version: Delphi6 when you are using Delphi version 6, Kylix3 if you are running Kylix version 3, etc. Open that subdirectory and open any Delphi package of your choice. After youve opened the package, click Install in the Delphi package dialog window to install the selected Library.

Figure 3.1.: DWS II tab with Common Libraries installed

Release Candidate 2

3. DWS II Standard Libraries

C ONVENTION

45

3. DWS II Standard Libraries H INT

Do not forget to update your Library-Path settings!

3.1. COM - Connector

Listing 3.1: Connectors: COM


{ COM c o n n e c t o r d e f i n e s two d a t a t y p e s : " ComVariant " and " ComVariantArray " }
2

c o n s t ComOpt : V a r i a n t = [ v a r E r r o r ] ;
4

{ F u n c t i o n t o c r e a t e a new COM b j e c t : C r e a t e s an COM O o b j e c t and r e t u r n s a p o i n t e r t o t h e I D i s p a t c h i n t e r f a c e . See Delphi h e l p f o r C r e a t e O l e O b j e c t . } f u n c t i o n C r e a t e O l e O b j e c t ( ClassName : S t r i n g ) : ComVariant ;

3.2. Internal Functions


Most of the internal functions are always available in DWS II scripts. Only the GUI, GlobalVar and File functions have to be manually included by dropping the appropriate components onto the form. The procedures print and println are built into the TDelphiWebScriptII component. procedure Print(Output: String); Adds Output without adding CRLF to TProgram.Result procedure PrintLn(Output: String); Adds Output + CRLF to TProgram.Result Note that you can not use PrintLn if you want to add one - in the web browser visible - line feed to a HTML page!

46

N OTE

Release Candidate 2

3.2. Internal Functions

3.2.1. Maths Functions

Listing 3.2: Internal Functions: Maths

10

12

14

16

18

20

22

R e g i s t e r I n t e r n a l F u n c t i o n ( TSinFunc , Sin , [ a , c F l o a t ] , cFloat ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TSinhFunc , Sinh , [ a , c F l o a t ] , cFloat ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TCosFunc , Cos , [ a , c F l o a t ] , cFloat ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TCoshFunc , Cosh , [ a , c F l o a t ] , cFloat ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TTanFunc , Tan , [ a , c F l o a t ] , cFloat ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TTanhFunc , Tanh , [ a , c F l o a t ] , cFloat ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TArcSinFunc , ArcSin , [ v , cFloat ] , cFloat ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TArcSinhFunc , ArcSinh , [ v , cFloat ] , cFloat ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TArcCosFunc , ArcCos , [ v , cFloat ] , cFloat ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TArcCoshFunc , ArcCosh , [ v , cFloat ] , cFloat ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TArcTanFunc , ArcTan , [ v , cFloat ] , cFloat ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TArcTanhFunc , ArcTanh , [ v , cFloat ] , cFloat ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TCotanFunc , Cotan , [ a , c F l o a t ] , cFloat ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( THypotFunc , Hypot , [ x , c F l o a t , y , c F l o a t ] , c F l o a t ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TIncFunc , Inc , [ @a , c I n t e g e r , b , c I n t e g e r ] , c I n t e g e r ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TAbsFunc , Abs , [ v , c F l o a t ] , cFloat ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TExpFunc , Exp , [ v , c F l o a t ] , cFloat ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TLnFunc , Ln , [ v , c F l o a t ] , cFloat ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TLog2Func , Log2 , [ v , c F l o a t ] , cFloat ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TLog10Func , Log10 , [ v , c F l o a t ] , cFloat ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TLogNFunc , LogN , [ n , c F l o a t , x , c F l o a t ] , c F l o a t ) ;

Release Candidate 2

47

3. DWS II Standard Libraries


R e g i s t e r I n t e r n a l F u n c t i o n ( T S q r t F u n c , Sqrt , [ v , c F l o a t ] , cFloat ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TSqrFunc , Sqr , [ v , c F l o a t ] , cFloat ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T I n t F u n c , Int , [ v , c F l o a t ] , cFloat ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TFracFunc , Frac , [ v , c F l o a t ] , cFloat ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TTruncFunc , Trunc , [ v , c F l o a t ] , cInteger ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TRoundFunc , Round , [ v , c F l o a t ] , cInteger ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TPowerFunc , Power , [ base , c F l o a t , exponent , c F l o a t ] , c F l o a t ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TDegToRadFunc , DegToRad , [ a , cFloat ] , cFloat ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TRadToDegFunc , RadToDeg , [ a , cFloat ] , cFloat ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TMaxFunc , Max , [ v1 , c F l o a t , v2 , c F l o a t ] , c F l o a t ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TMinFunc , Min , [ v1 , c F l o a t , v2 , c F l o a t ] , c F l o a t ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TPiFunc , Pi , [ ] , c F l o a t ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TRandomFunc , Random , [ ] , c F l o a t ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TRandomIntFunc , RandomInt , [ range , c I n t e g e r ] , c I n t e g e r ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TRandomizeFunc , Randomize , [ ] , ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TRandGFunc , RandG , [ mean , c F l o a t , stdDev , c F l o a t ] , c F l o a t ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TRandSeedFunc , RandSeed , [ ] , cInteger ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TSetRandSeedFunc , SetRandSeed , [ seed , c I n t e g e r ] , ) ;

24

26

28

30

32

34

36

38

40

48

Release Candidate 2

3.2. Internal Functions 3.2.1.1. Math Trigonometric Utilities DWS II Reference Sin, Sinh Tan, Tanh Returns the (hyperbolic) tangent of the angle in radians.

Returns the (hyperbolic) sine of the angle in Declaration radians. function Tan(X: Float): Float; function TanH(X: Float): Float; Declaration Description The Tan function returns the tangent of the argument. (Tan(x) = Sin(x) / Cos(x)) X is a real-type expression. Tan returns the tangent of the angle X in radians. function Sin(X: Float): Float; function SinH(X: Float): Float; Description

Tanh calculates the hyperbolic tangent of X. The Sin function returns the sine of the argument. X is a real-type expression. Sin returns the ArcSin, ArcSinh sine of the angle X in radians. Calculates the inverse (hyperbolic) sine of a given number. Sinh calculates the hyperbolic sine of X. Declaration Cos, Cosh Returns the (hyperbolic) cosine of the angle in radians. Declaration function Cos(X: Float): Float; function CosH(X: Float): Float; Description function ArcSin(X: Float): Float; function ArcSinH(X: Float): Float; Description ArcSin returns the inverse sine of X. X must be between -1 and 1. The return value will be in the range [-Pi/2..Pi/2], in radians. ArcSinh returns the inverse hyperbolic sine of X. ArcCos, ArcCosh

Calculates the inverse (hyperbolic) cosine of a The cosine function returns the cosine of the given number. argument. X is a real-type expression. Cos returns the Declaration sine of the angle X in radians. function ArcCos(X: Float): Float; function ArcCosH(X: Float): Float; Cosh calculates the hyperbolic cosine of X.

Release Candidate 2

49

3. DWS II Standard Libraries Description DegToRad

ArcTan, ArcTanh

RadToDeg Calculates the inverse (hyperbolic) tangent of Converts radians to degrees. a given number. Declaration function ArcTan(X: Float): Float; function ArcTanH(X: Float): Float; Description ArcTan returns the arctangent of X. ArcTanh returns the inverse hyperbolic tangent of X. The value of X must be between -1 and 1 (inclusive). Cotan Calculates the cotangent of an angle. Declaration function CoTan(X: Float): Float; Description Call Cotan to obtain the cotangent of X. The cotangent is calculated using the formula 1 / Tan(X) Do not call Cotan with X = 0! Pi Returns 3.1415926535897932385. Declaration function Pi: Float; Description Use Pi in mathematical calculations that require pi Declaration function RadToDeg(x:Float): Float;

50

Release Candidate 2

ArcCos returns the inverse cosine of X. X Returns the value of a degree measurement exmust be between -1 and 1. The return value pressed in radians. will be in the range [0..Pi], in radians. ArcCosh returns the inverse hyperbolic co- Declaration sine of X. function DegToRad(x: Float): Float;

3.2. Internal Functions 3.2.1.2. Math Float Utilities - DWS II Reference Abs Abs returns the absolute value of the argument, X. X is a oat-type expression Declaration function Abs(x: Float): Float; Exp LogN LogN returns the log base Base of X.

function Sqrt(x: Float): Float; Returns the value of a degree measurement expressed in radians. Sqr Declaration function Exp(x: Float): Float; Ln The Sqr function returns the square of the argument. X is a oating-point expression. The result, of the same type as X, is the square of X, or X*X.

Returns the value of a degree measurement ex- Declaration pressed in radians. function Sqr(x: Float): Float; Declaration function Ln(x: Float): Float; Log2 Log2 returns the log base 2 of X. Declaration Frac function Log2(x: Float): Float; Log10 Log10 returns the log base 10 of X. Declaration function Log10(x: Float): Float; The Frac function returns the fractional part of the argument X. X is a real-type expression. The result is the fractional part of X; that is, Frac(X) = X - Int(X). Declaration function Frac(x: Float): Float; Int Int returns the integer part of X; that is, X rounded toward zero. X is a real-type expression. Declaration function Int(x: Float): Float;

Release Candidate 2

Declaration function LogN(Base, x: Float): Float;

Sqrt

X is a oating-point expression. The result is the square root of X. Declaration

51

3. DWS II Standard Libraries Trunc Min

Declaration function Trunc(x: Float): Integer; Round

The Round function rounds a real-type value to an integer-type value. X is a real-type expression. Round returns an Integer value that is the value of X rounded to the nearest whole number. If X is exactly halfway between two whole numbers, the result is always the even number. This method of rounding is often called Bankers Rounding. Note: The behavior of Round can be affected by the Set8087CW procedure or SetRoundMode function. Declaration function Round(x: Float): Integer; Power Power raises Base to any power. For fractional exponents or exponents greater than MaxInt, Base must be greater than 0. Declaration

function Power(Base, Exponent: Float): Float; Max Call Max to compare two numeric values. Max returns the greater value of the two. Declaration function Max(v1,v2: Float): Float;

52

Release Candidate 2

The Trunc function truncates a real-type value Call Min to compare two numeric values. Min to an integer-type value. X is a real-type ex- returns the smaller value of the two. pression. Trunc returns an Integer value that is Declaration the value of X rounded toward zero. function Min(v1,v2: Float): Float;

3.2. Internal Functions 3.2.1.3. Math Random Utilities - DWS II Reference Random Returns a random number within the range 0 < =X<1 Declaration function Random: Float; RandomInt Returns a random number within the range 0 < = X < Range; x e IN Declaration function RandomInt(Range: Integer): Integer; Randomize Randomize initializes the built-in random number generator with a random value (obtained from the system clock). The random number generator should be initialized by making a call to Randomize, or by assigning a value to RandSeed. Do not combine the call to Randomize in a loop with calls to the Random function. Typically, Randomize is called only once, before all calls to Random. Declaration procedure Randomize; RandG RandG produces random numbers with Gaussian distribution about the Mean. This is useful for simulating data with sampling errors and expected deviations from the Mean. Declaration function RandG(Mean, StdDev: Float): Float; RandSeed Get the value of the Delphi-RandSeed variable.

Release Candidate 2

Declaration function RandSeed: Integer;

SetRandSeed Set the Delphi RandSeed variable. Declaration procedure SetRandSeed(val: Integer);

53

3. DWS II Standard Libraries 3.2.1.4. Math Misc. Utilities - DWS II Reference Inc Increments a by b. Declaration procedure Inc(a,b: Integer); Hypot Calculates the length of the hypotenuse. Declaration function Hypot(x, y: Float): Float;

54

Release Candidate 2

3.2. Internal Functions

3.2.2. String Functions

Listing 3.3: Internal Functions: String Functions

10

12

14

16

18

20

22

R e g i s t e r I n t e r n a l F u n c t i o n ( T I n t T o S t r F u n c , IntToStr , [ i , cInteger ] , cString ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T S t r T o I n t F u n c , StrToInt , [ str , cString ] , cInteger ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T S t r T o I n t D e f F u n c , StrToIntDef , [ str , c S t r i n g , def , c I n t e g e r ] , c I n t e g e r ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TIntToHexFunc , IntToHex , [ v , c I n t e g e r , digits , c I n t e g e r ] , c S t r i n g ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T F l o a t T o S t r F u n c , FloatToStr , [ f , cFloat ] , cString ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T S t r T o F l o a t F u n c , StrToFloat , [ str , c S t r i n g ] , c F l o a t ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T S t r T o F l o a t D e f F u n c , StrToFloatDef , [ str , c S t r i n g , def , c F l o a t ] , c F l o a t ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TChrFunc , Chr , [ x , c I n t e g e r ] , cString ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TOrdFunc , Ord , [ s , c S t r i n g ] , cInteger ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TCharAtFunc , CharAt , [ s , c S t r i n g , x , c I n t e g e r ] , c S t r i n g ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TSetCharAtFunc , SetCharAt , [ @s , c S t r i n g , x , c I n t e g e r , c , c S t r i n g ] , ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T D e l e t e F u n c , Delete , [ @S , c S t r i n g , Index , c I n t e g e r , Len , c I n t e g e r ] , ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T I n s e r t F u n c , Insert , [ src , c S t r i n g , @S , c S t r i n g , Index , c I n t e g e r ] , ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TLowerCaseFunc , LowerCase , [ str , cString ] , cString ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TAnsiLowerCaseFunc , AnsiLowerCase , [ str , c S t r i n g ] , c S t r i n g ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TUpperCaseFunc , UpperCase , [ str , cString ] , cString ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TAnsiUpperCaseFunc , AnsiUpperCase , [ str , c S t r i n g ] , c S t r i n g ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TPosFunc , Pos , [ subStr , c S t r i n g , str , c S t r i n g ] , c I n t e g e r ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TLengthFunc , Length , [ str , cString ] , cInteger ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T S e t L e n g t h F u n c , SetLength , [ @S , c S t r i n g , NewLength , c I n t e g e r ] , ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T T r i m L e f t F u n c , TrimLeft , [ str , cString ] , cString ) ;

Release Candidate 2

55

3. DWS II Standard Libraries


R e g i s t e r I n t e r n a l F u n c t i o n ( TTrimRightFunc , TrimRight , [ str , cString ] , cString ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TTrimFunc , Trim , [ str , c S t r i n g ] , cString ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TCompareTextFunc , CompareText , [ str1 , c S t r i n g , str2 , c S t r i n g ] , c I n t e g e r ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TAnsiCompareTextFunc , AnsiCompareText , [ str1 , c S t r i n g , str2 , c S t r i n g ] , cInteger ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TCompareStrFunc , CompareStr , [ str1 , c S t r i n g , str2 , c S t r i n g ] , c I n t e g e r ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TAnsiCompareStrFunc , AnsiCompareStr , [ str1 , c S t r i n g , str2 , c S t r i n g ] , cInteger ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T I s D e l i m i t e r F u n c , IsDelimiter , [ delims , c S t r i n g , s , c S t r i n g , index , c I n t e g e r ] , cBoolean ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T L a s t D e l i m i t e r F u n c , LastDelimiter , [ delims , c S t r i n g , s , c S t r i n g ] , c B o o l e a n ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T Q u o t e d S t r F u n c , QuotedStr , [ str , cString ] , cString ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TCopyFunc , Copy , [ str , c S t r i n g , Index , c I n t e g e r , Len , c I n t e g e r ] , c S t r i n g ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T L e f t S t r F u n c , LeftStr , [ AText , c S t r i n g , ACount , c I n t e g e r ] , c S t r i n g ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T R i g h t S t r F u n c , RightStr , [ AText , c S t r i n g , ACount , c I n t e g e r ] , c S t r i n g ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TMidStrFunc , MidStr , [ AText , c S t r i n g , AStart , c I n t e g e r , ACount , c I n t e g e r ] , c S t r i n g ); R e g i s t e r I n t e r n a l F u n c t i o n ( T S t r i n g O f C h a r F u n c , StringOfChar , [ Ch , c S t r i n g , Count , c I n t e g e r ] , c S t r i n g ) ;

24

26

28

30

32

34

36

Please note that most of the Delphi function descriptions below are taken from the Delphi help. For your convenience we chose to replicate them here.

56

Release Candidate 2

3.2. Internal Functions 3.2.2.1. String Utilities - DWS II Reference IntToStr FloatToStr

function IntToStr(i: Integer): String; StrToInt

StrToInt converts the string S, which represents an integer-type number in either decimal or hex- StrToFloat adecimal notation, into a number. If S does not represent a valid number, StrToInt raises an Use StrToFloat to convert a string, S, to a oatingpoint value. S must consist of an optional sign EDelphi exception. (+ or -), a string of digits with an optional deciDeclaration mal point, and an optional mantissa. The mantissa consists of E or e followed by an opfunction StrToInt(S: String): Integer; tional sign (+ or -) and a whole number. Leading and trailing blanks are ignored. StrToIntDef The DecimalSeparator global variable denes StrToIntDef converts the string S, which repre- the character that must be used as a decimal sents an integer-type number in either decimal point. Thousand separators and currency symor hexadecimal notation, into a number. If S bols are not allowed in the string. If S doesnt does not represent a valid number, StrToIntDef contain a valid value, StrToFloat raises an EConreturns the number passed in Default. vertError (=EDelphi) exception. Declaration function StrToIntDef(const S: string; Default: Integer): Integer; IntToHex IntToHex converts a number into a string con- StrToFloatDef taining the numbers hexadecimal (base 16) repSame as StrToFloat but if the conversion fails resentation. Value is the number to convert. the result value is parameter def . Digits indicates the minimum number of hexadecimal digits to return. Declaration Declaration function IntToHex(Value: Integer; Digits: function StrToFloatDef(const S: string; def: Integer): string; oat): oat; Declaration function StrToFloat(const S: string): oat;

Release Candidate 2

FloatToStr converts the oating-point value given by Value to its string representation. The conversion uses general number format with 15 IntToStr converts an integer into a string consignicant digits. taining the decimal representation of that numFor greater control over the formatting of the ber. string, use the FloatToStrF function. Declaration Declaration function FloatToStr(Value: Float): string;

57

3. DWS II Standard Libraries Chr Chr returns the character with the ordinal value (ASCII value) of the byte-type expression, X. Declaration function Chr( x: Integer): String; Ord Ord returns the ASCII value of char s. Declaration function Ord(s: String): Integer; CharAt Returns the char at position i from string x. Replacement for Delphi style result := x[i] Declaration Declaration procedure Delete(var S: string; Index, Count:Integer);

function CharAt(x: String; i: Integer): String; SetCharAt Sets the char at position i in string x to value. Replacement for Delphi style x[i] := value Declaration

LowerCase returns a string with the same text as the string passed in S, but with all letters procedure SetCharAt(var x:string; i: inte- converted to lowercase. The conversion affects ger; value: string); only 7-bit ASCII characters between A and Z. To convert 8-bit international characters, use AnsiLowerCase. Delete Delete removes a substring of Count characters from string S starting with S[Index]. S is a string-type variable. Index and Count are integer-type expressions. If index is larger than the length of the S or less than 1, no characters are deleted. If count species more characters than remain starting at the index, Delete removes the rest of the string. If count is less than 0, no characters are deleted. Declaration function LowerCase(S: string): string; AnsiLowerCase AnsiLowerCase returns a string that is a copy of the given string converted to lower case. The conversion uses the current locale. This function supports multi-byte character sets (MBCS).

58

Release Candidate 2

Insert Insert merges Source into S at the position S[index]. Source is a string-type expression. S is a string-type variable of any length. Index is an integer-type expression. It is a character index and not a byte index. If Index is less than 1, it is mapped to a 1. If it is past the end of the string, it is set to the length of the string, turning the operation into an append. If the Source parameter is an empty string, Insert does nothing. Insert throws an EOutOfMemory (=EDelphi) exception if it is unable to allocate enough memory to accommodate the new returned string. Declaration

procedure Insert(Source: string; var S: string; Index: Integer); LowerCase

3.2. Internal Functions Declaration function AnsiLowerCase(S: string): string; UpperCase SetLength Sets the length of string S to NewLength. Declaration

procedure SetLength(var S : String; NewLength UpperCase returns a copy of the string S, with : Integer); the same text but with all 7-bit ASCII characters between a and z converted to uppercase. To convert 8-bit international characters, TrimLeft use AnsiUpperCase instead. TrimLeft returns a copy of the string S with leading spaces and control characters removed. Declaration function UpperCase(S: string): string; AnsiUpperCase Declaration function TrimLeft(S: string): string;

AnsiUpperCase returns a string that is a copy of S, converted to upper case. The conversion uses the current locale. Note: This function supports multi-byte character sets (MBCS). Declaration function AnsiUpperCase(S: string): string; Pos

Trim removes leading and trailing spaces and Pos searches for a substring, Substr, in a string, control characters from the given string S. S. Substr and S are string-type expressions. Declaration Pos searches for Substr within S and returns function Trim(S: string): string; an integer value that is the index of the rst character of Substr within S. Pos is case-sensitive. CompareText If Substr is not found, Pos returns zero CompareText compares S1 and S2 and returns 0 if they are equal. If S1 is greater than S2, function Pos(Substr: string; S: string): InteCompareText returns an integer greater than 0. ger; If S1 is less than S2, CompareText returns an integer less than 0. CompareText is not case Length sensitive and is not affected by the current loLength returns the number of characters actu- cale. ally used in the string. Declaration Declaration Declaration function Length(S): Integer; function CompareText(S1, S2: string): Integer;

Release Candidate 2

TrimRight

TrimRight returns a copy of the string S with trailing spaces and control characters removed. Declaration function TrimRight(S: string): string;

Trim

59

3. DWS II Standard Libraries AnsiCompareText Declaration

AnsiCompareText compares S1 to S2, without function AnsiCompareStr( S1, S2: string): case sensitivity. The compare operation is controlled by the current locale. AnsiCompare- Integer; Text returns a value less than 0 if S1 < S2, a value greater than 0 if S1 > S2, and returns 0 if IsDelimiter S1 = S2. Call IsDelimiter to determine whether the charDeclaration acter at byte offset Index in the string S is one function AnsiCompareText(S1, S2: string): of the delimiters in the string Delimiters. Index is the 0-based index of the byte in question, Integer; where 0 is the rst byte of the string, 1 is the second byte, and so on. CompareStr When working with a multi-byte character CompareStr compares S1 to S2, with case sen- system (MBCS), IsDelimiter checks to make sitivity. The return value is less than 0 if S1 is sure the indicated byte is not part of a double less than S2, 0 if S1 equals S2, or greater than byte character. The delimiters in the Delime0 if S1 is greater than S2. The compare opera- ters parameter must all be single byte charaction is based on the 8-bit ordinal value of each ters. character and is not affected by the current locale. Declaration Declaration function IsDelimiter(Delimiters, S: string; function CompareStr(S1, S2: string): Inte- Index: Integer): Boolean; ger; AnsiCompareStr LastDelimiter

AnsiCompareStr compares S1 to S2, with case Call LastDelimiter to locate the last delimiter sensitivity. The compare operation is controlled in S. For example, the line by the current locale. The return value is: MyIndex := LastDelimiter(\.:,c:\lename.ext); Condition Return Value sets MyIndex to 12. S1 > S2 > 0 When working with multi-byte character sets S1 < S2 < 0 (MBCS), S may contain double byte characS1 = S2 = 0 ters, but the delimiters listed in the DelimeNote: Most locales consider lowercase char- ters parameter must all be single byte non-null acters to be less than the corresponding upper- characters. case characters. This is in contrast to ASCII order, in which lowercase characters are greater than uppercase characters. Thus, AnsiCom- Declaration pareStr(a,A) returns a value less than zero, while CompareStr(a,A) returns a value greater function LastDelimiter(Delimiters, S: string): than zero. Integer;

60

Release Candidate 2

3.2. Internal Functions QuotedStr MidStr

Declaration function QuotedStr( S: string): string; Copy S is an expression of a string. Index and Count are integer-type expressions. Copy returns a substring containing Count characters or elements starting at S[Index]. If Index is larger than the length of S, Copy returns an empty string or array. If Count species more characters than are available, only the characters from S[Index] to the end of S are returned. Declaration function Copy(S: String; Index, Count: Integer): String; LeftStr

Does a Copy(Info[AText], 1, integer(info[ACount])); Declaration function LeftStr(AText: String; ACount: Integer): String; RightStr Does a Copy(Info[AText], Length(Info[AText]) + 1 - integer(info[ACount]), integer(info[ACount])); Declaration function RightStr(AText: String; ACount: Integer): String;

Release Candidate 2

Use QuotedStr to convert the string S to a quoted Does a Copy(Info[AText], integer(info[AStart]), string. A single quote character () is inserted integer(info[ACount])); at the beginning and end of S, and each single Declaration quote character in the string is repeated. function MidStr(AText: String; AStart, ACount: Integer): string; StringOfChar StringOfChar returns a string containing Count characters with the character value given by Ch. For example, S := StringOfChar(A, 10); sets S to the string AAAAAAAAAA. Declaration function StringOfChar(Ch : String; Count : Integer) : String;

61

3. DWS II Standard Libraries

3.2.3. Time Functions


Listing 3.4: Internal Functions: DateTime Functions

10

12

14

16

18

R e g i s t e r I n t e r n a l F u n c t i o n ( TNowFunc , Now , [ ] , cDateTime ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TDateFunc , Date , [ ] , cDateTime ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TTimeFunc , Time , [ ] , cDateTime ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TDateTimeToStrFunc , DateTimeToStr , [ dt , cDateTime ] , c S t r i n g ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TStrToDateTimeFunc , StrToDateTime , [ str , c S t r i n g ] , cDateTime ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T D a t e T o S t r F u n c , DateToStr , [ dt , cDateTime ] , c S t r i n g ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T S t r T o D a t e F u n c , StrToDate , [ str , c S t r i n g ] , cDateTime ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TTimeToStrFunc , TimeToStr , [ dt , cDateTime ] , c S t r i n g ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TStrToTimeFunc , StrToTime , [ str , c S t r i n g ] , cDateTime ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TDayOfWeekFunc , DayOfWeek , [ dt , cDateTime ] , c I n t e g e r ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TFormatDateTimeFunc , FormatDateTime , [ frm , c S t r i n g , dt , cDateTime ] , cString ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T I s L e a p Y e a r F u n c , IsLeapYear , [ year , c I n t e g e r ] , c B o o l e a n ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TIncMonthFunc , IncMonth , [ dt , cDateTime , nb , c I n t e g e r ] , cDateTime ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TDecodeDateFunc , DecodeDate , [ dt , cDateTime , @y , c I n t e g e r , @m , c I n t e g e r , @d , c I n t e g e r ] , ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TEncodeDateFunc , EncodeDate , [ y , c I n t e g e r , m , c I n t e g e r , d , c I n t e g e r ] , cDateTime ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TDecodeTimeFunc , DecodeTime , [ dt , cDateTime , @h , c I n t e g e r , @m , c I n t e g e r , @s , c I n t e g e r , @ms , c I n t e g e r ] , ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TEncodeTimeFunc , EncodeTime , [ h , c I n t e g e r , m , c I n t e g e r , s , c I n t e g e r , ms , c I n t e g e r ] , cDateTime ) ;

62

Release Candidate 2

3.2. Internal Functions 3.2.3.1. Time Utilities - DWS II Reference Now Declaration function DateTimeToStr(DateTime: TDateTime): string;

Returns the current date and time, corresponding to Date + Time. Note: Although TDateTime values can rep- StrToDateTime resent milliseconds, Now only returns the time Call StrToDate to parse a string that species to the closest second. a date and time value. If S does not contain a valid date, StrToDate raises an EConvertError Declaration (=EDelphi) exception. The S parameter must use the current locales function Now: TDateTime; date/time format. In the US, this is commonly MM/DD/YY HH:MM:SS format. Specifying Date AM or PM as part of the time is optional, as Use Date to obtain the current local date as are the seconds. Use 24-hour time (7:45 PM is a TDateTime value. The time portion of the entered as 19:45, for example) if AM or PM is value is 0 (midnight). not specied. Y2K issue: The conversion of two-digit year Declaration values is determined by the TwoDigitYearCenturyWindow variable. For more information, see function Date: TDateTime; StrToDate. Note: The format of the date and time string Time varies when the values of date/time formatting Time returns the current time as a TDateTime variables are changed. value. Declaration Declaration function Time: TDateTime; DateTimeToStr The function DateTimeToString converts the TDateTime value given by DateTime using the format given by the ShortDateFormat global Delphi variable, followed by the time using the format given by the LongTimeFormat global Delphi variable. The time is not displayed if the fractional part of the DateTime value is zero. To change how the string is formatted, change ShortDateFormat and LongTimeFormat global date time formatting variables in Delphi. DateToStr Use DateToStr to obtain a string representation of a date value that can be used for display purposes. The conversion uses the format specied by the ShortDateFormat global variable. Declaration function DateToStr(Date: TDateTime): string; function StrToDateTime(const S: string): TDateTime;

Release Candidate 2

63

3. DWS II Standard Libraries


date = mm/dd/68

StrToDate

Release Candidate 2 TwoDigit-

date = mm/dd/50 date = mm/dd/03 Pivot Current year

S must consist of two or three numbers, separated by the character dened by the DateSeparator global Delphi variable. The order for month, day, and year is determined by the ShortDateFormat global Delphi variable - possible combinations are m/d/y, d/m/y, and y/m/d.

Note: The format of the date string varies when the values of date/time formatting variables are changed. Declaration function StrToDate(const S: string): TDateTime; TimeToStr

If S contains only two numbers, it is interpreted as a date (m/d or d/m) in the current year.

Year values between 0 and 99 are converted using the TwoDigitYearCenturyWindow global Delphi variable. If TwoDigitYearCenturyWindow is 0, year values between 0 and 99 are assumed to be in the current century. If TwoDigitYearCenturyWindow is greater than 0, its value is subtracted from the current year to determine the pivot; years on or after the pivot are kept in the current century, while years prior to the pivot are moved to the next century. For example:

TimeToStr converts the Time parameter, a TDateTime value, to a string. The conversion uses the format specied by the LongTimeFormat global Delphi variable. Change the format of the string by changing the values of some of the date and time Delphi variables. Declaration function TimeToStr(Time: TDateTime): string;

64

1998 2002 1998 2000 2002 2020 2020

YearCenturyWindow 0 0 50 50 50 50 10

1900 2000 1948 1950 1952 1970 2010

Call StrToDate to parse a string that species a date. If S does not contain a valid date, StrToDate raises an EConvertError (=EDelphi) exception.

1903 2003 2003 2003 2003 2003 2103

1950 2050 1950 1950 2050 2050 2050

1968 2068 1968 1968 1968 2068 2068

3.2. Internal Functions If the string specied by the Format parameter is empty, the TDateTime value is formatted Call StrToTime to parse a string that species as if a c format specier had been given. a time value. If S does not contain a valid time, StrToTime raises an EConvertError (=EDelphi) Declaration exception. function FormatDateTime(Format: string; The S parameter must consist of two or three DateTime: TDateTime): string; numbers, separated by the character dened by the TimeSeparator global variable, optionally followed by an AM or PM indicator. The num- IsLeapYear bers represent hour, minute, and (optionally) Call IsLeapYear to determine whether the year second, in that order. If the time is followed specied by the Year parameter is a leap year. by AM or PM, it is assumed to be in 12-hour Year species the calendar year. clock format. If no AM or PM indicator is included, the time is assumed to be in 24-hour Declaration clock format. function IsLeapYear(Year: Integer): Boolean; Note: The format of the date and time string varies when the values of date/time formatting IncMonth Delphi variables are changed. IncMonth returns the value of the Date parameter, incremented by NumberOfMonths months. function StrToTime(const S: string): TDate- NumberOfMonths can be negative, to return a date N months previous. Time; If the input day of month is greater than the last day of the resulting month, the day is set to DayOfWeek the last day of the resulting month. The time of DayOfWeek returns the day of the week of the day specied by the Date parameter is copied specied date as an integer between 1 and 7, to the result. where Sunday is the rst day of the week and Declaration Saturday is the seventh. Note: DayOfWeek is not compliant with the function IncMonth(Date: TDateTime; NumISO 8601 standard, which denes Monday as berOfMonths: Integer): TDateTime; the rst day of the week. Declaration Declaration DecodeDate StrToTime

The DecodeDate procedure breaks the value function DayOfWeek(Date: TDateTime): Inspecied as the Date parameter into Year, Month, teger; and Day values. If the given TDateTime value has a negative (BC) year, the year, month, and FormatDateTime day return parameters are all set to zero. FormatDateTime formats the TDateTime value Declaration given by DateTime using the format given by Format. See Date-Time format strings in the procedure DecodeDate(Date: TDateTime; Delphi help for more information. var Year, Month, Day: Integer);

Release Candidate 2

65

3. DWS II Standard Libraries EncodeDate The resulting value is a number between 0 and 1 (inclusive) that indicates the fractional EncodeDate returns a TDateTime value from part of a day given by the specied time or (if the values specied as the Year, Month, and 1.0) midnight on the following day. The value Day parameters. 0 corresponds to midnight, 0.5 corresponds to The year must be between 1 and 9999. noon, 0.75 corresponds to 6:00 pm, and so on. Valid Month values are 1 through 12. Valid Day values are 1 through 28, 29, 30, Declaration or 31, depending on the Month value. For example, the possible Day values for month 2 function EncodeTime(Hour, Min, Sec, MSec: (February) are 1 through 28 or 1 through 29, Integer): TDateTime; depending on whether or not the Year value species a leap year. If the specied values are not within range, EncodeDate raises an EConvertError (= EDelphi) exception. Declaration function EncodeDate(Year, Month, Day: Integer): TDateTime; DecodeTime DecodeTime breaks the object specied as the Time parameter into hours, minutes, seconds, and milliseconds. Declaration procedure DecodeTime(Time: TDateTime; var Hour, Min, Sec, MSec: Integer); EncodeTime EncodeTime encodes the given hour, minute, second, and millisecond into a TDateTime value. Valid Hour values are 0 through 24. If Hour is 24, Min, Sec, and MSec must all be 0, and the resulting TDateTime value represents midnight (12:00:00:000 AM) of the following day. Valid Min and Sec values are 0 through 59. Valid MSec values are 0 through 999. If the specied values are not within range, EncodeTime raises an EConvertError exception.

66

Release Candidate 2

3.2. Internal Functions

3.2.4. Variant Functions

Listing 3.5: Internal Functions: Variant Functions

10

12

14

16

18

20

22

24

p r o c e d u r e I n i t V a r i a n t s ( S y s t e m T a b l e , UnitSyms , U n i t T a b l e : TSymbolTable ) ; var T , E : TTypeSymbol ; begin T : = S y s t e m T a b l e . FindSymbol ( Integer ) a s TTypeSymbol ; E : = T En um er a ti on Sy m bo l . C r e a t e ( TVarType , T ) ; U n i t T a b l e . AddSymbol ( E ) ; U n i t T a b l e . AddSymbol ( TElementSymbol . C r e a t e ( varEmpty , E , varEmpty , T r u e ) ) ; U n i t T a b l e . AddSymbol ( TElementSymbol . C r e a t e ( varNull , E , varNull , True ) ) ; U n i t T a b l e . AddSymbol ( TElementSymbol . C r e a t e ( varSmallint , E , v a r S m a l l i n t , True ) ) ; U n i t T a b l e . AddSymbol ( TElementSymbol . C r e a t e ( varInteger , E , v a r I n t e g e r , True ) ) ; U n i t T a b l e . AddSymbol ( TElementSymbol . C r e a t e ( varSingle , E , v a r S i n g l e , True ) ) ; U n i t T a b l e . AddSymbol ( TElementSymbol . C r e a t e ( varDouble , E , varDouble , True ) ) ; U n i t T a b l e . AddSymbol ( TElementSymbol . C r e a t e ( varCurrency , E , varCurrency , True ) ) ; U n i t T a b l e . AddSymbol ( TElementSymbol . C r e a t e ( varDate , E , varDate , True ) ) ; U n i t T a b l e . AddSymbol ( TElementSymbol . C r e a t e ( varOleStr , E , v a r O l e S t r , True ) ) ; U n i t T a b l e . AddSymbol ( TElementSymbol . C r e a t e ( varDispatch , E , v a r D i s p a t c h , True ) ) ; U n i t T a b l e . AddSymbol ( TElementSymbol . C r e a t e ( varError , E , v a r E r r o r , True ) ) ; U n i t T a b l e . AddSymbol ( TElementSymbol . C r e a t e ( varBoolean , E , varBoolean , True ) ) ; U n i t T a b l e . AddSymbol ( TElementSymbol . C r e a t e ( varVariant , E , v a r V a r i a n t , True ) ) ; U n i t T a b l e . AddSymbol ( TElementSymbol . C r e a t e ( varUnknown , E , varUnknown , T r u e ) ) ; U n i t T a b l e . AddSymbol ( TElementSymbol . C r e a t e ( varShortInt , E , v a r S h o r t I n t , True ) ) ; U n i t T a b l e . AddSymbol ( TElementSymbol . C r e a t e ( varByte , E , varByte , True ) ) ; U n i t T a b l e . AddSymbol ( TElementSymbol . C r e a t e ( varWord , E , varWord , T r u e ) ) ;

Release Candidate 2

67

3. DWS II Standard Libraries


26

Release Candidate 2

28

30

32

U n i t T a b l e . AddSymbol ( TElementSymbol . E , varLongWord , T r u e ) ) ; U n i t T a b l e . AddSymbol ( TElementSymbol . v a r I n t 6 4 , True ) ) ; U n i t T a b l e . AddSymbol ( TElementSymbol . , varStrArg , True ) ) ; U n i t T a b l e . AddSymbol ( TElementSymbol . , v a r S t r i n g , True ) ) ; U n i t T a b l e . AddSymbol ( TElementSymbol . varAny , T r u e ) ) ; U n i t T a b l e . AddSymbol ( TElementSymbol . E , varTypeMask , T r u e ) ) ; U n i t T a b l e . AddSymbol ( TElementSymbol . varArray , True ) ) ; U n i t T a b l e . AddSymbol ( TElementSymbol . varByRef , T r u e ) ) ;

C r e a t e ( varLongWord , C r e a t e ( varInt64 , E , C r e a t e ( varStrArg , E C r e a t e ( varString , E C r e a t e ( varAny , E , C r e a t e ( varTypeMask , C r e a t e ( varArray , E , C r e a t e ( varByRef , E ,

34

36

38

40

42

44

T : = S y s t e m T a b l e . FindSymbol ( Variant ) a s TTypeSymbol ; U n i t T a b l e . AddSymbol ( TConstSymbol . C r e a t e ( Null , T , N u l l ) ) ; U n i t T a b l e . AddSymbol ( TConstSymbol . C r e a t e ( Unassigned , T , Unassigned ) ) ; end ; initialization RegisterInternalInitProc ( @InitVariants ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T V a r C l e a r F u n c , VarClear , [ @v , c V a r i a n t ] , ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T V a r I s N u l l F u n c , VarIsNull , [ v , c V a r i a n t ] , cBoolean ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TVarIsEmptyFunc , VarIsEmpty , [ v , c V a r i a n t ] , c B o o l e a n ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TVarAsTypeFunc , VarAsType , [ v , c V a r i a n t , VarType , c I n t e g e r ] , c V a r i a n t ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TVarToStrFunc , VarToStr , [ v , cVariant ] , cString ) ; end .

46

68

3.2. Internal Functions 3.2.4.1. Variant Utilities - DWS II Reference Null Use Null to obtain a Null Variant that can indicate unknown or missing data. Null Variants can be assigned to variables in an application that must contain a null value. Assigning Null to a variant variable does not cause an error, and Null can be returned from any function with a variant return value. Expressions involving Null Variants always result in a Null Variant. Thus, Null is said to propagate through intrinsic functions that return variant data types. If any part of the expression evaluates to Null, the entire expression evaluates to Null. Declaration const Null: Variant; Unassigned The Unassigned constant is used to indicate that a variant has not yet been assigned a value. The initial value of any variant is Unassigned. The Unassigned value disappears as soon as a variant is assigned any other value, including the value 0, a zero-length string, and the Null value. Use the VarIsEmpty internal function to test whether a variant is Unassigned. When used on an Unassigned variant, the VarType internal function returns varEmpty. An EVariantError (=EDelphi) exception is raised if an Unassigned variant appears in any other expression or an attempt is made to convert an Unassigned variant to another type (using VarAsType). You can make a variant unassigned by assigning the Unassigned return value to it.. Declaration const Unassigend: Variant; VarIsEmpty returns True if the given variant contains the value Unassigned. If the variant VarClear Calling VarClear is equivalent to assigning the Unassigned value to the Variant. V can be either a Variant or an OleVariant, but it must be possible to assign a value to it (it must be an lvalue). After calling VarClear, the VarIsEmpty function returns True. Using an unassigned variant in an expression causes an EVariantError (=EDelphi) exception to be thrown. Likewise, if you attempt to convert an unassigned Variant to another type (using VarAsType ), an EVariantError (=EDelphi) exception is thrown. Note: Do not confuse clearing a Variant, which leaves it unassigned, with assigning a Null value. A Null Variant is still assigned, but has the value Null. Unlike unassigned Variants, Null Variants can be used in expressions and can be converted to other types of Variants. Declaration procedure VarClear(V: Variant); VarIsNull VarIsNull returns True if the given variant contains the value Null. If the variant contains any other value, the function result is False. Note: Do not confuse a Null variant with an unassigned variant. A Null variant is still assigned, but has the value Null. Unlike unassigned variants, Null variants can be used in expressions and can be converted to other types of variants. Declaration function VarIsNull(const V: Variant): Boolean; VarIsEmpty

Release Candidate 2

69

3. DWS II Standard Libraries contains any other value, the function result is Declaration False. function VarToStr(const V: Variant): String; Note: Do not confuse an unassigned variant with a Null variant. A Null variant is still assigned, but has the value Null. Unlike unassigned variants, Null variants can be used in expressions and can be converted to other types of variants. Declaration

function VarIsEmpty(const V: Variant): Boolean; VarAsType

VarAsType converts a variant to a specied type and returns a new Variant that has the specied type. V is the Variant to convert. VarType is a variant type code that indicates the type to which V should be converted. This can be one of the constants dened by the dws2VariantFunctions Delphi unit, or it can be the integer type code for a custom variant type. It cannot include the varArray or varByRef bits. VarAsType throws an EVariantError (= EDelphi) exception if the variant cannot be converted to the given type. Following VarTypes are available: varEmpty, varNull, varSmallint, varInteger, varSingle, varDouble, varCurrency, varDate, varOleStr, varDispatch, varError, varBoolean, varVariant, varUnknown, varShortInt, varByte, varWord, varLongWord, varInt64, varStrArg, varString, varAny, varTypeMask, varArray, varByRef. Declaration function VarAsType(V: Variant; VarType: Integer): Variant; VarToStr VarToStr converts the data in the variant V to a string and returns the result. If the variant has a null value, VarToStr returns an empty string.

70

Release Candidate 2

3.2. Internal Functions

3.2.5. FileFunctions (Component)


Due to security reasons the le functions are NOT included by default! If you want to allow your scripts access to the local le system, you have to drop the FileFunctions component onto the form that contains the TDelphiWebScriptII component. Including the le functions may lead to security problems! For web development we strongly discourage the use of this component, but suggest that you write your own access functions that provide only access to the les you absolutely need.

Listing 3.6: Internal Functions: File Functions

10

12

14

R e g i s t e r I n t e r n a l F u n c t i o n ( TSaveStringToFileFunc , SaveStringToFile , [ fileName , c S t r i n g , data , c S t r i n g ] , ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TLoadStringFromFileFunc , LoadStringFromFile , [ fileName , c S t r i n g ] , c S t r i n g ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TAppendStringToFileFunc , AppendStringToFile , [ fileName , c S t r i n g , data , c S t r i n g ] , ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T F i l e E x i s t s F u n c , FileExists , [ fileName , c S t r i n g ] , c B o o l e a n ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T D e l e t e F i l e F u n c , DeleteFile , [ fileName , c S t r i n g ] , c B o o l e a n ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TRenameFileFunc , RenameFile , [ oldName , c S t r i n g , newName , c S t r i n g ] , c B o o l e a n ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TChDirFunc , ChDir , [ s , c S t r i n g ] , ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T C r e a t e D i r F u n c , CreateDir , [ dir , c S t r i n g ] , cBoolean ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TRemoveDirFunc , RemoveDir , [ dir , c S t r i n g ] , cBoolean ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T G e t C u r r e n t D i r F u n c , GetCurrentDir , [ ] , cString ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T S e t C u r r e n t D i r F u n c , SetCurrentDir , [ dir , c S t r i n g ] , c B o o l e a n ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T F i l e S e a r c h F u n c , FileSearch , [ name , c S t r i n g , dirList , c S t r i n g ] , c S t r i n g ) ; RegisterInternalFunction ( TExtractFileDriveFunc , ExtractFileDrive , [ fName , c S t r i n g ] , c S t r i n g ) ; RegisterInternalFunction ( TExtractFileDirFunc , ExtractFileDir , [ fName , c S t r i n g ] , c S t r i n g ) ;

Release Candidate 2

ATTENTION

71

3. DWS II Standard Libraries


16

72

Release Candidate 2

18

R e g i s t e r I n t e r n a l F u n c t i o n ( TExtractFileNameFunc , ExtractFileName , [ fName , c S t r i n g ] , c S t r i n g ) ; RegisterInternalFunction ( TExtractFilePathFunc , ExtractFilePath , [ fName , c S t r i n g ] , c S t r i n g ) ; RegisterInternalFunction ( TExtractFileExtFunc , ExtractFileExt , [ fName , c S t r i n g ] , c S t r i n g ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T C h a n g e F i l e E x t F u n c , ChangeFileExt , [ fName , c S t r i n g , ext , c S t r i n g ] , c S t r i n g ) ;

3.2. Internal Functions 3.2.5.1. File Utilities - DWS II Reference DeleteFile SaveStringToFile DeleteFile deletes the le named by FileName from the disk. If the le cannot be deleted or does not exist, the function returns False.

Declaration procedure SaveStringToFile(FileName, Data: String); LoadStringFromFile

Returns contents of le "lename" as string. File FileName is opened using the fmShareDenyNone ag. Declaration Note that this function might throw an EDelphi exception, if the le can not be opened. function RenameFile(OldName, NewName: string): Boolean; Declaration function LoadStringFromFile(FileName: string): String; AppendStringToFile Adds string "Data" to le "FileName" Declaration Declaration procedure AppendStringToFile(FileName, Data: String); FileExists procedure ChDir(S: string); CreateDir ChDir ChDir changes the current directory to the path specied by S. You may get an EDelphi exception when calling this function and an IOError occurred.

FileExists returns True if the le specied by CreateDir creates a new directory. The return FileName exists. If the le does not exist, File- value is True if a new directory was successExists returns False. fully created, or False if an error occurred. Declaration function FileExists(FileName: string): Boolean; Declaration function CreateDir(Dir: string): Boolean;

Release Candidate 2

Saves string "data" to le "lename". Note: SaveStringToFile creates the le if it does not exist. Otherwise the le is opened in Declaration write mode. The function might throw an EDelphi excepfunction DeleteFile(FileName: string): Boolean; tion if the le can not be opened / created. RenameFile

RenameFile attempts to change the name of the le specied by OldFile to NewFile. If the operation succeeds, RenameFile returns True. If it cannot rename the le (for example, if a le called NewName already exists), it returns False.

73

3. DWS II Standard Libraries RemoveDir Call RemoveDir to remove the directory specied by the Dir parameter. The return value is True if a new directory was successfully deleted, False if an error occurred. The directory must be empty before it can be successfully deleted. Declaration function RemoveDir(Dir: string): Boolean; GetCurrentDir GetCurrentDir returns the fully qualied name of the current directory. Declaration function GetCurrentDir: string; SetCurrentDir ExtractFileDrive ExtractFileDrive returns a string containing the drive portion of a fully qualied path name for the le passed in the FileName. For le names with drive letters, the result is in the form <drive>. For le names with a UNC path the result is in the form . If the given path contains neither style of path prex, the result is an empty string. Declaration function ExtractFileDrive(FileName: string): string; ExtractFileDir

The resulting string is a directory name suitable for passing to the CreateDir, RemoveDir, The SetCurrentDir function sets the current di- and SetCurrentDir functions. This string is empty rectory. The return value is True if the current if FileName contains no drive and directory parts. directory was successfully changed, or False if an error occurred. Declaration Declaration function SetCurrentDir(Dir: string): Boolean; FileSearch function ExtractFileDir(const FileName: string): string; ExtractFileName

The resulting string is the rightmost characters FileSearch searches through the directories passed in DirList for a le named Name. DirList of FileName, starting with the rst character is a list of path names delimited by semicolons after the colon or backslash that separates the on Windows (colons on Linux). If FileSearch path information from the name and extension. locates a le matching Name, it returns a string The resulting string is equal to FileName if Filespecifying a path name for that le. If no match- Name contains no drive and directory parts. ing le exists, FileSearch returns an empty string. Declaration Declaration

function FileSearch(Name, DirList: string): function ExtractFileName(FileName: string): string; string;

74

Release Candidate 2

3.2. Internal Functions ExtractFilePath The resulting string is the leftmost characters of FileName, up to and including the colon or backslash that separates the path information from the name and extension. The resulting string is empty if FileName contains no drive and directory parts. Declaration function ExtractFilePath(FileName: string): string; ExtractFileExt

Use ExtractFileExt to obtain the extension from a le name. For example, the following code returns the extension of the le name specied by a variable named MyFileName: MyFilesExtension := ExtractFileExt(MyFileName); The resulting string includes the period character that separates the name and extension parts. This string is empty if the given le name has no extension. Declaration function ExtractFileExt(FileName: string): string; ChangeFileExt ChangeFileExt takes the le name passed in FileName and changes the extension of the le name to the extension passed in Extension. Extension species the new extension, including the initial dot character. ChangeFileExt does not rename the actual le, it just creates a new le name string. Declaration function ChangeFileExt(FileName, Extension: string): string;

Release Candidate 2

75

3. DWS II Standard Libraries

3.2.6. GUI Functions (Component)


Often the GUI functions are not needed in script. Due to this fact and the separation of the runtime packages into a version that depends on VCL and one that depends on CLX, the GUI functions are provided in a separate component and not included by default. If you want to use them, simply drop the GUI Functions component onto the form containing the TDelphiWebScriptII component. If you use this component:

H INT

You have to redistribute the dws2VCLRuntime package - if you want to ship your VCL program using runtime packages. Redistribute the dws2CLXRuntime package, if you are using the CLX and ship your program with runtime packages. Of course you also need to ship the dws2Runtime package in addition to the package mentioned above.

Listing 3.7: Internal Functions: GUI Functions

R e g i s t e r I n t e r n a l F u n c t i o n ( TShowMessageFunc , ShowMessage , [ msg , c S t r i n g ] , ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TInputBoxFunc , InputBox , [ aCaption , c S t r i n g , aPrompt , c S t r i n g , aDefault , cString ] , cString ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T E r r o r D l g F u n c , ErrorDlg , [ msg , c S t r i n g ] , ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TInformationDlgFunc , InformationDlg , [ msg , c S t r i n g ] , ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( T Q u e s t i o n D l g F u n c , QuestionDlg , [ msg , c S t r i n g ] , c B o o l e a n ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TOkCancelDlgFunc , OkCancelDlg , [ msg , c S t r i n g ] , c B o o l e a n ) ;

76

Release Candidate 2

3.2. Internal Functions 3.2.6.1. GUI Utilities - DWS II Reference the message box. The message box contains an error icon. ShowMessage Msg parameter is the message string that apCall ShowMessage to display a simple mes- pears in the message box. sage box with an OK button. The name of the Note: If the user types Ctrl+C in the mesapplications executable le appears as the cap- sage box, the text of the message is copied to tion of the message box. the clipboard. Msg parameter is the message string that appears in the message box. Declaration Note: If the user types Ctrl+C in the message box, the text of the message is copied to procedure ErrorDlg(Msg: string); the clipboard. Declaration procedure ShowMessage(Msg: string); InputBox

Call InputBox to bring up an input dialog box ready for the user to enter a string in its edit box. ACaption is the caption of the dialog box. APrompt is the text that prompts the user to enter input in the edit box. ADefault is the string that appears in the edit box when the dialog box rst appears. If the user chooses the Cancel button, InDeclaration putBox returns the default string. If the user chooses the OK button, InputBox returns the procedure InformationDlg(Msg: string); string in the edit box. Use the InputBox function when there is a default value that should be used when the user QuestionDlg chooses the Cancel button (or presses Esc) to exit the dialog. The message box contains an icon showing a question mark and two buttons "Yes" and "No". Declaration Msg parameter is the message string that apfunction InputBox(ACaption, APrompt, ADe- pears in the message box. fault: string): string; The return value is true if the "Yes" button was pressed and false otherwise. ErrorDlg

Call ErrorDlg to display a simple message box Declaration with an OK button. The name of the applications executable le appears as the caption of function QuestionDlg(Msg: string): Boolean;

Release Candidate 2

InformationDlg

Call InformationDlg to display a simple message box with an OK button. The name of the applications executable le appears as the caption of the message box. The message box contains an icon showing an exclamation sign. Msg parameter is the message string that appears in the message box. Note: If the user types Ctrl+C in the message box, the text of the message is copied to the clipboard.

77

3. DWS II Standard Libraries OkCancelDlg The message box contains an icon showing a question mark and two buttons "Yes" and "Cancel". Msg parameter is the message string that appears in the message box. The return value is true if the "Yes" button was pressed and false otherwise. Declaration

function OkCancelDlg(Msg: string): Boolean;

78

Release Candidate 2

3.2. Internal Functions

3.2.7. Global Variable Functions (Component)


This component implements global variables functions, that allow scripts to read and write to variables across a scripts context. Details: Variables can be declared and read from any script, or from Delphi code Read/Write access is thread-safe Variables names are case sensitive

Fast, (reads/writes per second on a 800MHz Duron and a handful of variables: 100k/sec, 1000k with optimization using D5) The global variables can be saved/restored as a whole only from Delphi code (Delphi code only as of now, mainly for security reasons) to a le, string or stream. Be aware DWS II will require special care to run in a multi-threaded environment. Listing 3.8: Internal Functions: Global Variable Functions

{ => F o l l o w i n g f u n c t i o n s a r e d e f i n e d i n DWSII s c r i p t : } R e g i s t e r I n t e r n a l F u n c t i o n ( TReadGlobalVarFunc , ReadGlobalVar , [ n , c S t r i n g ] , c V a r i a n t ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TReadGlobalVarDefFunc , ReadGlobalVarDef , [ n , c S t r i n g , d , c V a r i a n t ] , cVariant ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TWriteGlobalVarFunc , WriteGlobalVar , [ n , c S t r i n g , v , c V a r i a n t ] , ) ; R e g i s t e r I n t e r n a l F u n c t i o n ( TCleanupGlobalVarsFunc , CleanupGlobalVars , [ ] , ) ;

10

12

{ => F o l l o w i n g DELPHI f u n c t i o n s a r e a v a i l a b l e t o a c c e s s t h e stored variables : }


14

16

{ D i r e c t l y w r i t e a global var . } p r o c e d u r e W r i t e G l o b a l V a r ( c o n s t aName : s t r i n g ; c o n s t a V a l u e : Variant ) ; { D i r e c t l y read a g l o b a l var . } f u n c t i o n R e a d G l o b a l V a r ( c o n s t aName : s t r i n g ) : V a r i a n t ; { D i r e c t l y r e a d a g l o b a l var , u s i n g a d e f a u l t v a l u e i f v a r i a b l e does not e x i s t s . }

18

20

Release Candidate 2

79

3. DWS II Standard Libraries


22

f u n c t i o n R e a d G l o b a l V a r D e f ( c o n s t aName : s t r i n g ; c o n s t aDefault : Variant ) : Variant ; { Resets a l l global vars . } procedure CleanupGlobalVars ;

24

26

28

{ S a v e c u r r e n t g l o b a l v a r s and t h e i r v a l u e s t o a f i l e . } function SaveGlobalVarsToString : string ; { Load g l o b a l v a r s and t h e i r v a l u e s t o a f i l e . } procedure LoadGlobalVarsFromString ( const s r c S t r i n g : s t r i n g ) ; { S a v e c u r r e n t g l o b a l v a r s and t h e i r v a l u e s t o a f i l e . } function SaveGlobalVarsToFile ( const destFileName : string ) : Boolean ; { Load g l o b a l v a r s and t h e i r v a l u e s t o a f i l e . } function LoadGlobalVarsFromFile ( const srcFileName : string ) : Boolean ; { S a v e c u r r e n t g l o b a l v a r s and t h e i r v a l u e s t o a f i l e . } p r o c e d u r e S a v e G l o b a l V a r s T o S t r e a m ( d e s t S t r e a m : TStream ) ; { Load g l o b a l v a r s and t h e i r v a l u e s t o a f i l e . } p r o c e d u r e L o a d G l o b a l V a r s F r o m S t r e a m ( s r c S t r e a m : TStream ) ;

30

32

34

36

38

40

42

80

Release Candidate 2

3.2. Internal Functions 3.2.7.1. GVar Utilities - DWS II Reference ReadGlobalVar Returns the value of the global variable n. This function returns an empty variant, if the variable can not be found. Declaration function ReadGlobalVar(n: String): Variant; ReadGlobalVarDef Similar to ReadGlobalVar, except that d is given back in case the variable specied by n could not be found. Declaration

function ReadGlobalVarDef(n: String; d: Variant): Variant; WriteGlobalVar Assigns value of v to the global variable named n. WriteGlobalVar creates a new global variable (with name n), if it can not nd an existing global variable with the name specied by n. Declaration procedure WriteGlobalVar(n: String; v: Variant); CleanupGlobalVars Deletes and frees all global variables. Declaration procedure CleanupGlobalVars;

Release Candidate 2

81

3. DWS II Standard Libraries

3.3. Strings Unit

Dws2StringsUnit demands that TDelphiWebScriptIIs resulttype is set to dws2StringResultType! In other words: To use this component, you also have to drop the RES str labeled dws2StringResultType component onto the form that contains the TDelphiWebScriptII component and you have to set the TDelphiWebScriptII.Cong.ResultType property to the dws2StringResultType component.

Listing 3.9: Strings Unit: Functions


p r o c e d u r e T d w s 2 S t r i n g s U n i t . AddUnitSymbols ( S y m b o l T a b l e : TSymbolTable ) ; var emptyArg : a r r a y o f s t r i n g ; begin T W r i t e F u n c t i o n . C r e a t e ( SymbolTable , WriteStr , [ Str , SYS_VARIANT ] , ) ; T W r i t e L n F u n c t i o n . C r e a t e ( SymbolTable , WriteLn , [ Str , SYS_VARIANT ] , ) ; T W r i t e A l l F u n c t i o n . C r e a t e ( SymbolTable , WriteAll , [ Str , SYS_VARIANT ] , ) ; S e t L e n g t h ( emptyArg , 0 ) ; T R e a d C h a r F u n c t i o n . C r e a t e ( SymbolTable , ReadChar , emptyArg , SYS_STRING ) ; T R e a d L n F u n c t i o n . C r e a t e ( SymbolTable , ReadLn , emptyArg , SYS_STRING ) ; T R e a d A l l F u n c t i o n . C r e a t e ( SymbolTable , ReadAll , emptyArg , SYS_STRING ) ; end ;

10

12

The string unit introduces following procedures: WriteStr( Str: Variant); WriteLn( Str: Variant);

82

Release Candidate 2

ATTENTION

3.4. Classes Library WriteAll( Str: Variant); Additionally following functions are available:

ReadLn: String; ReadAll: String;

3.4. Classes Library

The classes library denes wrappers for commonly used Delphi classes. Listing 3.10 shows all types that are dened by this library. The listing below was created with the help of the dws2UnitEditor. You can nd this utility in the dws2tools/UnitCompEditor module. Note: This component is still in development, thus not 100% stable. N OTE

Listing 3.10: Standard Library: Classes Library


{ Forward D e c l a r a t i o n s } type T S t r i n g L i s t = c l a s s ; { Constants } const dupAccept : I n t e g e r = 2 ; const dupError : I n t e g e r = 1 ; const dupIgnore : I n t e g e r = 0 ; { Classes } type TList = c l a s s ( TObject ) constructor Create ; f u n c t i o n Add ( Obj : T O b j e c t ) : I n t e g e r ; procedure C l e a r ; f u n c t i o n Count : I n t e g e r ; p r o c e d u r e D e l e t e ( Index : I n t e g e r ) ; destructor Destroy ; override ; f u n c t i o n G e t I t e m s ( Index : I n t e g e r ) : T O b j e c t ; f u n c t i o n I n d e x O f ( Obj : T O b j e c t ) : I n t e g e r ;

10

12

14

16

18

Release Candidate 2

ReadChar: String;

83

3. DWS II Standard Libraries


20

22

24

26

28

30

32

34

36

38

40

42

44

46

48

50

52

54

56

58

60

62

type T S t r i n g s = c l a s s ( TObject ) constructor Create ; f u n c t i o n Add ( S t r : S t r i n g ) : I n t e g e r ; f u n c t i o n AddObject ( S : S t r i n g ; AObject : TObject ) : Integer ; procedure Add Stri ngs ( S t r i n g s : T S t r i n g L i s t ) ; procedure C l e a r ; p r o c e d u r e D e l e t e ( Index : I n t e g e r ) ; destructor Destroy ; override ; p r o c e d u r e Exchange ( I n d e x 1 : I n t e g e r ; I n d e x 2 : I n t e g e r ) ; f u n c t i o n Get ( Index : I n t e g e r ) : S t r i n g ; f u n c t i o n GetCommaText : S t r i n g ; f u n c t i o n GetCount : I n t e g e r ; f u n c t i o n GetNames ( s : S t r i n g ) : S t r i n g ; f u n c t i o n G e t O b j e c t s ( Index : I n t e g e r ) : T O b j e c t ; f u n c t i o n G e t S t r i n g s ( Index : I n t e g e r ) : S t r i n g ; function GetText : String ; function GetValues ( Str : String ) : String ; function IndexOf ( Str : String ) : I n t e g e r ; f u n c t i o n IndexOfName ( S t r : S t r i n g ) : I n t e g e r ; f u n c t i o n IndexOfObject ( AObject : TObject ) : I n t e g e r ; p r o c e d u r e I n s e r t ( Index : I n t e g e r ; S t r : S t r i n g ) ; p r o c e d u r e I n s e r t O b j e c t ( Index : I n t e g e r ; S : S t r i n g ; AObject : TObject ) ; p r o c e d u r e L o a d F r o m F i l e ( FileName : S t r i n g ) ; p r o c e d u r e Move ( C u r I n d e x : I n t e g e r ; NewIndex : I n t e g e r ) ; p r o c e d u r e S a v e T o F i l e ( FileName : S t r i n g ) ; p r o c e d u r e SetCommaText ( V a l u e : S t r i n g ) ; p r o c e d u r e S e t O b j e c t s ( Index : I n t e g e r ; V a l u e : T O b j e c t ) ; p r o c e d u r e S e t S t r i n g s ( Index : I n t e g e r ; V a l u e : S t r i n g ) ; procedure S e t T e x t ( Value : S t r i n g ) ; procedure S e t V a l u e s ( Str : S t r i n g ; Value : S t r i n g ) ; p r o p e r t y CommaText : S t r i n g read GetCommaText w r i t e SetCommaText ; p r o p e r t y Count : I n t e g e r read G e t C o u n t ; p r o p e r t y Names [ s : S t r i n g ] : S t r i n g read GetNames ; p r o p e r t y O b j e c t s [ x : I n t e g e r ] : T O b j e c t read G e t O b j e c t s write SetObjects ; p r o p e r t y S t r i n g s [ x : I n t e g e r ] : S t r i n g read G e t S t r i n g s write S e t S t r i n g s ; default ; p r o p e r t y T e x t : S t r i n g read G e t T e x t w r i t e S e t T e x t ;

84

Release Candidate 2

p r o c e d u r e I n s e r t ( Index : I n t e g e r ; Obj : T O b j e c t ) ; f u n c t i o n Remove ( Obj : T O b j e c t ) : I n t e g e r ; p r o c e d u r e S e t I t e m s ( Index : I n t e g e r ; V a l u e : T O b j e c t ) ; p r o p e r t y I t e m s [ x : I n t e g e r ] : T O b j e c t read G e t I t e m s write SetItems ; default ; end ;

3.4. Classes Library


p r o p e r t y V a l u e s [ s : S t r i n g ] : S t r i n g read G e t V a l u e s write SetValues ; end ;

64

68

70

72

74

76

78

80

82

type THashtable = c l a s s ( TObject ) function Capacity : Integer ; procedure C l e a r ; function Size : Integer ; end ;

84

86

88

90

92

type TIntegerHashtable = c l a s s ( THashtable ) constructor Create ; destructor Destroy ; override ; f u n c t i o n Get ( Key : I n t e g e r ) : T O b j e c t ; f u n c t i o n HasKey ( Key : I n t e g e r ) : B o o l e a n ; p r o c e d u r e P u t ( Key : I n t e g e r ; V a l u e : T O b j e c t ) ; f u n c t i o n RemoveKey ( Key : I n t e g e r ) : T O b j e c t ; end ; type TStringHashtable = c l a s s ( THashtable ) constructor Create ; destructor Destroy ; override ; f u n c t i o n Get ( Key : S t r i n g ) : T O b j e c t ; f u n c t i o n HasKey ( Key : S t r i n g ) : B o o l e a n ; p r o c e d u r e P u t ( Key : S t r i n g ; V a l u e : T O b j e c t ) ; f u n c t i o n RemoveKey ( Key : S t r i n g ) : T O b j e c t ; end ; type TStack = c l a s s ( TObject ) constructor Create ;

94

96

98

100

102

104

106

Release Candidate 2

66

type TStringList = class ( TStrings ) f u n c t i o n F i n d ( S : S t r i n g ; var Index : I n t e g e r ) : Boolean ; function GetDuplicates : Integer ; function GetSorted : Boolean ; procedure S e t D u p l i c a t e s ( Value : I n t e g e r ) ; procedure S e t S o r t e d ( Value : Boolean ) ; procedure S o r t ; p r o p e r t y D u p l i c a t e s : I n t e g e r read G e t D u p l i c a t e s w r i t e SetDuplicates ; p r o p e r t y S o r t e d : B o o l e a n read G e t S o r t e d w r i t e S e t S o r t e d ; end ;

85

3. DWS II Standard Libraries


108

110

114

116

118

120

122

type TQueue = c l a s s ( T O b j e c t ) constructor Create ; f u n c t i o n Count : I n t e g e r ; destructor Destroy ; override ; f u n c t i o n Peek : T O b j e c t ; f u n c t i o n Pop : T O b j e c t ; p r o c e d u r e Push ( Obj : T O b j e c t ) ; end ;

We wont cover most of the types and methods here, because they are commonly used in Delphi and rely on the behavior of the equivalent native Delphi classes. Please consult your Delphi help, if you have questions regarding these types. THashTable, TIntegerHashTable and TStringHashTable provide script access to the types dened in the dws2Hashtables DWS II Delphi unit. You can nd this le in the Source directory of your DWS II installation. THashTable THashTable is the base class for all DWS II HashTable classes. Following methods are dened: function Size: Integer; Returns the number of stored items. function Capacity: Integer; Returns the number of items that may be stored without having to re-allocate memory. procedure Clear; Clears the HashTable. TIntegerHashTable Derived from THashTable, TIntegerHashTable can store any kind of objects that use an integer value as hash key. All methods should be self explanatory, so we do not cover them here. TStringHashTable Use TStringHashTable to store objects that have strings as hash keys.

86

Release Candidate 2

112

f u n c t i o n Count : I n t e g e r ; destructor Destroy ; override ; f u n c t i o n Peek : T O b j e c t ; f u n c t i o n Pop : T O b j e c t ; p r o c e d u r e Push ( Obj : T O b j e c t ) ; end ;

3.5. Database Libraries (IBX, IBO)

3.5. Database Libraries (IBX, IBO)

Especially for web applications it is crucial to have fast, reliable and exible access to databases. The IBX and IBO Libraries shipping with DWS II implement several features that enable DWS II to fulll this demand. Consider the functionality IBXLib offers as DWS II database connectivity standard. The IBO Library sticks to that standard, so whenever you are reading IBX here, you can think of IBX and IBO. N OTE

3.5.1. dws2IBXDataBase, dws2IBODataBase


Component to add more TIB_Connections if you use more than one database. DWS Queries and Statements can be created with database as parameter.

3.5.2. dws2IBXDataSrc, dws2IBODataSrc


Component to add a predened TIB_Query, TIB_Cursor or TIB_Statement as script object that can be used in the script without creation or prepare.

3.5.3. dws2IBXLib, dws2IBOLib


Listing 3.11: Standard Library: IBX / IBO Library
{ Forward D e c l a r a t i o n s } type TDataset = c l a s s ; { Classes } type TDatabase = c l a s s ( TObject ) constructor c r e a t e ( database : String ; user : String ; pwd : S t r i n g ) ;

Release Candidate 2

87

3. DWS II Standard Libraries


8

10

14

16

18

20

22

24

type TCustomDBField = c l a s s ( T O b j e c t ) function GetValue : V a r i a n t ; v i r t u a l ; function GetValueStr : String ; virtual ; procedure SetValue ( Value : V a r i a n t ) ; v i r t u a l ; procedure S e t V a l u e S t r ( Value : S t r i n g ) ; v i r t u a l ; p r o p e r t y A s S t r i n g : S t r i n g read G e t V a l u e S t r w r i t e SetValueStr ; end ; type TDBField = c l a s s ( TCustomDBField ) f u n c t i o n GetDateTime : DateTime ; function GetFloat : Float ; function GetInteger : Integer ; p r o c e d u r e S e t D a t e T i m e ( V a l u e : DateTime ) ; procedure S e t F l o a t ( Value : F l o a t ) ; procedure S e t I n t e g e r ( Value : I n t e g e r ) ; p r o p e r t y AsDateTime : DateTime read GetDateTime w r i t e SetDateTime ; p r o p e r t y A s F l o a t : F l o a t read G e t F l o a t w r i t e S e t F l o a t ; p r o p e r t y A s I n t e g e r : I n t e g e r read G e t I n t e g e r w r i t e SetInteger ; p r o p e r t y A s S t r i n g : S t r i n g read G e t V a l u e S t r w r i t e SetValueStr ; p r o p e r t y V a l u e : V a r i a n t read G e t V a l u e w r i t e S e t V a l u e ; end ; type TLUField = c l a s s ( TCustomDBField ) f u n c t i o n GetDateTime : DateTime ; function GetFloat : Float ; function GetInteger : Integer ; function GetValue : V a r i a n t ; override ; function GetValueStr : String ; override ; p r o c e d u r e S e t D a t e T i m e ( V a l u e : DateTime ) ; procedure S e t F l o a t ( Value : F l o a t ) ;

26

28

30

32

34

36

38

40

42

44

46

48

50

88

Release Candidate 2

12

procedure c o n n e c t ; procedure d i s c o n n e c t ; function g e t c h a r s e t : String ; function g e t d i a l e c t : Integer ; procedure s e t c h a r s e t ( s C h a r s e t : S t r i n g ) ; procedure s e t d i a l e c t ( i D i a l e c t : I n t e g e r ) ; p r o p e r t y c h a r s e t : S t r i n g read g e t c h a r s e t w r i t e setcharset ; p r o p e r t y d i a l e c t : I n t e g e r read g e t d i a l e c t w r i t e setdialect ; end ;

3.5. Database Libraries (IBX, IBO)


procedure S e t I n t e g e r ( Value : I n t e g e r ) ; procedure SetValue ( Value : V a r i a n t ) ; o v e r r i d e ; procedure S e t V a l u e S t r ( Value : S t r i n g ) ; o v e r r i d e ; p r o p e r t y AsDateTime : DateTime read GetDateTime w r i t e SetDateTime ; p r o p e r t y A s F l o a t : F l o a t read G e t F l o a t w r i t e S e t F l o a t ; p r o p e r t y A s I n t e g e r : I n t e g e r read G e t I n t e g e r w r i t e SetInteger ; p r o p e r t y A s S t r i n g : S t r i n g read G e t V a l u e S t r w r i t e SetValueStr ; p r o p e r t y V a l u e : V a r i a n t read G e t V a l u e w r i t e S e t V a l u e ; end ; type TMLUField = c l a s s c o n s t r u c t o r c r e a t e ( D a t a S e t : T D a t a s e t ; MLUFieldName : String ) ; destructor free ; f u n c t i o n G e t V a l u e ( Name : S t r i n g ) : S t r i n g ; p r o c e d u r e SetNameValue ( Name : S t r i n g ; V a l u e : S t r i n g ) ; end ; type TStatement = c l a s s constructor Create ; c o n s t r u c t o r CreateFromDB ( d a t a b a s e : T D a t a b a s e ) ; v i r t u a l ; procedure Execute ; f u n c t i o n F i e l d ( FieldName : S t r i n g ) : V a r i a n t ; f u n c t i o n FieldByName ( FieldName : S t r i n g ) : TDBField ; f u n c t i o n F i e l d I s N u l l ( FieldName : S t r i n g ) : B o o l e a n ; d e s t r u c t o r Free ; f u n c t i o n GetSQL : S t r i n g ; p r o c e d u r e Open ; v i r t u a l ; f u n c t i o n ParamByName ( ParamName : S t r i n g ) : TDBField ; p r o c e d u r e S e t P a r a m ( ParamName : S t r i n g ; V a l u e : V a r i a n t ) ; p r o c e d u r e SetSQL ( sSQL : S t r i n g ) ; p r o p e r t y SQL : S t r i n g read GetSQL w r i t e SetSQL ; end ; type TDataset = c l a s s ( TStatement ) constructor Create ; c o n s t r u c t o r CreateFromDB ( D a t a b a s e : T D a t a b a s e ) ; override ; procedure Cancel ; procedure Close ; procedure D e l e t e ;

52

54

56

58

60

62

64

66

68

70

72

74

76

78

80

82

84

86

88

90

92

Release Candidate 2

89

3. DWS II Standard Libraries


procedure E d i t ; f u n c t i o n Eof : B o o l e a n ; function F i r s t : Boolean ; procedure I n s e r t ; f u n c t i o n Next : B o o l e a n ; p r o c e d u r e Open ; o v e r r i d e ; procedure P o s t ; end ;

94

96

98

100

102

104

106

108

110

112

114

116

118

type TQuery = c l a s s ( T D a t a s e t ) constructor Create ; c o n s t r u c t o r CreateFromDB ( D a t a B a s e : T D a t a b a s e ) ; override ; function G e t F i l t e r : String ; function G e t F i l t e r e d : Boolean ; function GetSortOrder : Integer ; f u n c t i o n LookUp ( K e y F i e l d V a l u e : S t r i n g ) : TCustomDBField ; function P r i o r : Boolean ; procedure S e t F i l t e r ( F i l t e r S t r : S t r i n g ) ; procedure S e t F i l t e r e d ( F i l t e r e d : Boolean ) ; p r o c e d u r e S e t L o o k U p F i e l d s ( KeyFieldName : S t r i n g ; LUfieldName : S t r i n g ) ; procedure S e t S o r t O r d e r ( S o r t O r d e r : I n t e g e r ) ; p r o p e r t y F i l t e r : S t r i n g read G e t F i l t e r w r i t e S e t F i l t e r ; p r o p e r t y F i l t e r e d : B o o l e a n read G e t F i l t e r e d w r i t e SetFiltered ; p r o p e r t y S o r t O r d e r : I n t e g e r read G e t S o r t O r d e r w r i t e SetSortOrder ; end ; type TDataSetGrp = c l a s s constructor C r e a t e ( d a t a S e t : TDataset ; groupFieldName : String ) ; p r o c e d u r e AddRow ; p r o c e d u r e AddSumField ( FieldName : S t r i n g ) ; f u n c t i o n Changed : B o o l e a n ; f u n c t i o n Count : I n t e g e r ; d e s t r u c t o r Free ; procedure Reset ; procedure R e s t a r t ; f u n c t i o n SumOfField ( FieldName : S t r i n g ) : F l o a t ; end ;

120

122

124

126

128

130

90

Release Candidate 2

3.5. Database Libraries (IBX, IBO) LookUpField : special for web apps - dene a master-detail table relation, you can lookup details belonging to one master dataline (like with name=value in stringlists) when "name" eld is string.

DataSetGrp : DataSetGroup, special for reports - if you iterate through a dataset you can use DataSetGrp to watch changing of single eld values, calculate group sums and total sums (like all incomes listed per person and totals per person....). TDataSetGrp

.create(DataSet: TDataset; GroupFieldName: String); // DataSet should be prepared;!! .Free;

.Changed: boolean; will be false while the content of the GroupField stays the same while iterating through this dataset .AddSumField(FieldName: String); after create, before start iterating, add all eldnames of elds which should be added in the group or total .SumOfField(FieldName: String): oat; returns actual value of added eld values. is set to 0 with "reset" .Count: integer; returns the number of datarecords in this group. .AddRow; adds values of all elds .Restart; reset values for a new group, DOES NOT RESET FIELD SUMS .Reset; reset values AND FIELD SUMS for a new group Example: Listing 3.12: Standard Library: IBX / IBO Library - DataSetGrp Example
{ dws2IBO : T D a t a Se t G r p Demo }

Release Candidate 2

MLUField : MemoLookUpField .. special for web apps - dene a MemoField, you can lookup values with name=value from stringlist

91

3. DWS II Standard Libraries


4

10

12

14

16

18

20

22

24

26

28

30

3.6. Fiber Library

The Fiber Library enables the use of control scripts that "pause". It was intended for OpenGL (GLScene) scripting, with a runall being called(between rendering) each 100 ms or so... For further details, see the included demo. You can nd it in the FiberLibrary directory. Listing 3.13: Standard Library: Fiber

92

Release Candidate 2

var qAmounts : T D a t a s e t ; var g r p E m p l o y e e : T D a t a S e t G r p ; qAmounts : = T D a t a s e t . C r e a t e ; qAmounts . SQL : = select * from empl_amounts ; / / wages o f employees qAmounts . open ; g r p E m p l o y e e : = T D a t a S e t G r p . c r e a t e ( qAmounts , name ) ; g r p E m p l o y e e . AddSumField ( amount ) ; w h i l e n o t qAmounts . Eof do begin P r i n t ( name: ) ; P r i n t L n ( qAmounts . F i e l d ( name ) ) ; w h i l e n o t g r p E m p l o y e e . c h a n g e d do begin P r i n t ( qAmounts . F i e l d b y n a m e ( bill_date ) . v a l u e ) ; P r i n t ( , ) ; P r i n t L n ( qAmounts . F i e l d ( amount ) ) ; g r p E m p l o y e e . addrow ; qAmounts . Next ; i : = i +1; end ; P r i n t ( grpEmployee . count ) ; P r i n t ( -----------, sum: ) ; P r i n t L n ( g r p E m p l o y e e . SumOfField ( amount ) ) ; P r i n t l n ( ) ; grpEmployee . r e s e t ; end ;

3.7. Ini Library


procedure FiberMessage ( MessageText : S t r i n g ) ; f u n c t i o n G e t F i b e r D a t a ( Name : S t r i n g ) : S t r i n g ; procedure N e x t F i b e r ( ) ; p r o c e d u r e S e t F i b e r D a t a ( Name : S t r i n g ; V a l u e : S t r i n g ) ;

3.7. Ini Library

Listing 3.14: Standard Library: Ini


{ Classes } type TIniFile = class c o n s t r u c t o r C r e a t e ( FileName : S t r i n g ) ; procedure DeleteKey ( S e c t i o n : S t r i n g ; I d e n t : S t r i n g ) ; destructor Destroy ; override ; procedure E r a s e S e c t i o n ( S e c t i o n : S t r i n g ) ; function GetFilename : String ; f u n c t i o n ReadBool ( S e c t i o n : S t r i n g ; I d e n t : S t r i n g ; Default : Boolean ) : Boolean ; f u n c t i o n ReadDate ( S e c t i o n : S t r i n g ; Name : S t r i n g ; D e f a u l t : DateTime ) : DateTime ; f u n c t i o n ReadDateTime ( S e c t i o n : S t r i n g ; Name : S t r i n g ; D e f a u l t : DateTime ) : DateTime ; f u n c t i o n R e a d F l o a t ( S e c t i o n : S t r i n g ; Name : S t r i n g ; Default : Float ) : Float ; function ReadInteger ( Section : String ; Ident : String ; Default : I n t e g e r ) : I n t e g e r ; procedure ReadSection ( S e c t i o n : S t r i n g ; S t r i n g s : TStringList ) ; procedure R e a d S e c t i o n s ( S t r i n g s : T S t r i n g L i s t ) ; procedure R ea dS ec ti on Va l ue s ( S e c t i o n : S t r i n g ; S t r i n g s : TStringList ) ; function ReadString ( Section : String ; Ident : String ; Default : String ) : String ; f u n c t i o n ReadTime ( S e c t i o n : S t r i n g ; Name : S t r i n g ; D e f a u l t : DateTime ) : DateTime ; function S e c t i o n E x i s t s ( S e c t i o n : String ) : Boolean ;

10

12

14

16

18

Release Candidate 2

93

3. DWS II Standard Libraries


20

22

24

26

28

30

3.8. MF Library

There are lots of functions and constants dened in MF Library. Most of them, however, are only meaningful on Windows. We provide here a listing of all functions and constants dened by this Library! Dont expect them to be documented here - this would simply blow the 200 pages border... MFLib also comes with some demos! H INT Please use the documentation shipping with Delphi if you have questions regarding one of the constants/functions/classes below!

94

Release Candidate 2

procedure U p d a t e F i l e ; function ValueExists ( Section : String ; Ident : String ) : Boolean ; procedure WriteBool ( S e c t i o n : S t r i n g ; I d e n t : S t r i n g ; Value : Boolean ) ; p r o c e d u r e W r i t e D a t e ( S e c t i o n : S t r i n g ; Name : S t r i n g ; V a l u e : DateTime ) ; p r o c e d u r e W r i t e D a t e T i m e ( S e c t i o n : S t r i n g ; Name : S t r i n g ; V a l u e : DateTime ) ; p r o c e d u r e W r i t e F l o a t ( S e c t i o n : S t r i n g ; Name : S t r i n g ; Value : F l o a t ) ; procedure W r i t e I n t e g e r ( S e c t i o n : S t r i n g ; I d e n t : S t r i n g ; Value : I n t e g e r ) ; procedure W r i t e S t r i n g ( S e c t i o n : S t r i n g ; I d e n t : S t r i n g ; Value : S t r i n g ) ; p r o c e d u r e W r i t e T i m e ( S e c t i o n : S t r i n g ; Name : S t r i n g ; V a l u e : DateTime ) ; p r o p e r t y F i l e n a m e : S t r i n g read G e t F i l e n a m e ; end ;

3.8. MF Library

3.8.1. dws2MFLoader
This component enables you to load encrypted DWS II scripts.

3.8.2.1. Functions

Listing 3.15: Standard Library: MFLib - Basic


p r o c e d u r e Beep ; forward ; p r o c e d u r e Dec ( var I : I n t e g e r ) ; forward ; p r o c e d u r e Dec2 ( var I : I n t e g e r ; N : I n t e g e r ) ; forward ; p r o c e d u r e I n c ( var I : I n t e g e r ) ; forward ; p r o c e d u r e I n c 2 ( var I : I n t e g e r ; N : I n t e g e r ) ; forward ; f u n c t i o n G e t T i c k C o u n t : I n t e g e r ; forward ; p r o c e d u r e S l e e p ( mSecs : I n t e g e r ) ; forward ; p r o c e d u r e WriteLn ( T e x t : S t r i n g ) ; forward ;

3.8.3. Connection
3.8.3.1. Functions Listing 3.16: Standard Library: MFLib - Connection
{ Functions } f u n c t i o n C o n n e c t e d : B o o l e a n ; forward ; f u n c t i o n I P A d d r e s s : S t r i n g ; forward ;

3.8.4. Dialog
3.8.4.1. Functions Listing 3.17: Standard Library: MFLib - Dialog
function SelectStringDialog ( T i t l e : String ; Strings : TStringList ; Selected : Integer ) : Integer ;

Release Candidate 2

3.8.2. Basic

95

3. DWS II Standard Libraries

3.8.5. File
3.8.5.1. Constants DRIVE_UNKNOWN DRIVE_NO_ROOT_DIR DRIVE_REMOVABLE DRIVE_FIXED DRIVE_REMOTE DRIVE_CDROM DRIVE_RAMDISK FILEDATE_CREATION FILEDATE_LASTACCESS FILEDATE_LASTWRITE MOVEFILE_REPLACE_EXISTING MOVEFILE_COPY_ALLOWED

MOVEFILE_DELAY_UNTIL_REBOOT MOVEFILE_WRITE_THROUGH MOVEFILE_CREATE_HARDLINK MOVEFILE_FAIL_IF_NOT_TRACKABLE 3.8.5.2. Functions Listing 3.18: Standard Library: MFLib - File
f u n c t i o n DescCopy ( S o u r c e , T a r g e t : S t r i n g ) : B o o l e a n ; function DescListCreate ( Dir : String ) : T S t r i n g L i s t ; f u n c t i o n D e s c L i s t R e a d ( L i s t : T S t r i n g L i s t ; FileName : S t r i n g ) : String ;

96

Release Candidate 2

3.8. MF Library
4

10

12

14

16

18

20

22

24

26

28

f u n c t i o n DescMove ( S o u r c e , T a r g e t : S t r i n g ) : B o o l e a n ; f u n c t i o n DescRead ( F i l e n a m e : S t r i n g ) : S t r i n g ; f u n c t i o n D e s c W r i t e ( FileName , Desc : S t r i n g ) : B o o l e a n ; f u n c t i o n O p e n D i a l o g ( FileName , I n i t i a l D i r , T i t l e , D e f a u l t E x t , F i l t e r : String ; F i l t e r I n d e x : Integer ) : String ; f u n c t i o n O p e n D i a l o g M u l t i ( FileName , I n i t i a l D i r , T i t l e , DefaultExt , F i l t e r : String ; F i l t e r I n d e x : Integer ) : TStringList ; f u n c t i o n S a v e D i a l o g ( FileName , I n i t i a l D i r , T i t l e , D e f a u l t E x t , F i l t e r : String ; F i l t e r I n d e x : Integer ) : String ; f u n c t i o n CDClose ( D r i v e : I n t e g e r ) : B o o l e a n ; f u n c t i o n CDOpen ( D r i v e : I n t e g e r ) : B o o l e a n ; f u n c t i o n GetCRC32FromFile ( FileName : S t r i n g ) : I n t e g e r ; f u n c t i o n GetDriveName ( D r i v e : I n t e g e r ) : S t r i n g ; f u n c t i o n GetDriveNum ( D r i v e : S t r i n g ) : I n t e g e r ; function GetDriveReady ( Drive : I n t e g e r ) : Boolean ; function Ge tD riv eSe ri al ( Drive : I n t e g e r ) : String ; function GetDriveType ( Drive : I n t e g e r ) : I n t e g e r ; f u n c t i o n D i r e c t o r y E x i s t s ( DirName : S t r i n g ) : B o o l e a n ; f u n c t i o n D i r e c t o r y L i s t ( DirName : S t r i n g ; R e c u r s e , Hidden ) : TStringList ; f u n c t i o n CopyFile ( Source , T a r g e t : S t r i n g ; F a i l : Boolean ) : Boolean ; f u n c t i o n F i l e D a t e ( FileName : S t r i n g ; F l a g : I n t e g e r ) : DateTime ; f u n c t i o n F i l e L i s t ( FileName : S t r i n g ; R e c u r s e , Hidden , D i r s : Boolean ) : T S t r i n g L i s t ; f u n c t i o n F i l e S i z e ( FileName : S t r i n g ) : I n t e g e r ; f u n c t i o n MakePath ( D r i v e , Dir , Name , E x t : S t r i n g ) : S t r i n g ; f u n c t i o n MoveFile ( Source , T a r g e t : S t r i n g ) : Boolean ; f u n c t i o n MoveFileEx ( S o u r c e , T a r g e t : S t r i n g ; F l a g s : I n t e g e r ) : Boolean ; f u n c t i o n ReadOnlyPath ( Path : String ) : Boolean ; p r o c e d u r e S p l i t P a t h ( P a t h : S t r i n g ; var D r i v e , Dir , Name , E x t : String ) ; function S u b d i r e c t o r y E x i s t s ( Dir : String ) : Boolean ;

3.8.6. Info
3.8.6.1. Constants VER_UNKNOWN VER_WIN32S VER_WIN95

Release Candidate 2

97

3. DWS II Standard Libraries VER_WIN98 VER_WIN98SE

VER_WINNT VER_WINNT4 VER_WIN2000 3.8.6.2. Functions

Listing 3.19: Standard Library: MFLib - Info


function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function function GetAllUsersDesktopDirectory : String ; GetAllUsersProgramsDirectory : String ; GetAllUsersStartmenuDirectory : String ; GetAllUsersStartupDirectory : String ; GetAppdataDirectory : String ; GetCacheDirectory : String ; GetChannelFolderName : String ; GetCommonFilesDirectory : String ; GetComputerName : S t r i n g ; GetConsoleTitle : String ; GetCookiesDirectory : String ; GetCPUSpeed : S t r i n g ; GetDesktopDirectory : String ; GetDevicePath : String ; GetEnvironmentVariable : String ; GetFavoritesDirectory : String ; GetFontsDirectory : String ; GetHistoryDirectory : String ; GetLinkfolderName : String ; GetMediaPath : String ; GetNethoodDirectory : String ; GetPersonalDirectory : String ; GetPFAccessoriesName : String ; GetPrinthoodDirectory : String ; GetProgramfilesDirectory : String ; GetProgramsDirectory : String ; GetRecentDirectory : String ; GetSendtoDirectory : String ; GetSMAccessoriesName : S t r i n g ; GetStartmenuDirectory : String ; GetStartupDirectory : String ; GetSystemDirectory : String ;

10

12

14

16

18

20

22

24

26

28

30

32

98

Release Candidate 2

VER_WINME

3.8. MF Library
function function function function function function function function function function function function function GetTempDirectory : String ; GetTemplatesDirectory : String ; GetUserName : S t r i n g ; GetVersion : String ; GetWallpaperDirectory : String ; GetWindowsDirectory : String ; GetWindowsVersion : S t r i n g ; IsWin2000 : B o o l e a n ; IsWin9x : B o o l e a n ; IsWinNT : B o o l e a n ; IsWinNT4 : B o o l e a n ; SetComputerName : S t r i n g ; SetConsoleTitle : String ;

34

36

38

40

42

44

3.8.7. Registry
3.8.7.1. Constants HKEY_CLASSES_ROOT HKEY_CURRENT_USER HKEY_LOCAL_MACHINE HKEY_USERS HKEY_PERFORMANCE_DATA HKEY_CURRENT_CONFIG HKEY_DYN_DATA 3.8.7.2. Functions

Listing 3.20: Standard Library: MFLib - Registry


p r o c e d u r e R e g C r e a t e K e y ( MainKey : I n t e g e r ; SubKey : S t r i n g ) ; p r o c e d u r e R e g D e l e t e K e y ( MainKey : I n t e g e r ; SubKey : S t r i n g ) ; p r o c e d u r e R e g D e l e t e V a l u e ( MainKey : I n t e g e r ; SubKey : S t r i n g ; ValName : S t r i n g ) ; f u n c t i o n R e g R e a d I n t e g e r ( MainKey : I n t e g e r ; SubKey : S t r i n g ; ValName : S t r i n g ; ValDef : I n t e g e r ) : I n t e g e r ; f u n c t i o n R e g R e a d S t r i n g ( MainKey : I n t e g e r ; SubKey : S t r i n g ; ValName : S t r i n g ; ValDef : S t r i n g ) : S t r i n g ;

Release Candidate 2

99

3. DWS II Standard Libraries


6

10

3.8.8. Shell
3.8.8.1. Functions

Listing 3.21: Standard Library: MFLib - Shell


DesktopRefresh ;

3.8.9. String
3.8.9.1. Constants cdrLeft cdrRight 3.8.9.2. Functions Listing 3.22: Standard Library: MFLib - String
f u n c t i o n ANSI2OEM ( S : S t r i n g ) : S t r i n g ; f u n c t i o n ChangeTokenValue ( S : S t r i n g ; Name : S t r i n g ; V a l u e : String ; Delimiter : String ) : String ; f u n c t i o n Chr ( B y t e : I n t e g e r ) : S t r i n g ; f u n c t i o n CmpRE( S : S t r i n g ; RE : S t r i n g ) : B o o l e a n ; f u n c t i o n CmpWC( S : S t r i n g ; WC: S t r i n g ; Case : B o o l e a n ) : Boolean ;

100

Release Candidate 2

f u n c t i o n RegGetType ( MainKey : I n t e g e r ; SubKey : S t r i n g ; ValName : S t r i n g ; var S i z e : I n t e g e r ) : I n t e g e r ; f u n c t i o n R e g K e y E x i s t s ( MainKey : I n t e g e r ; SubKey : S t r i n g ) : Boolean ; f u n c t i o n R e g V a l u e E x i s t s ( MainKey : I n t e g e r ; SubKey : S t r i n g ; ValName : S t r i n g ) : B o o l e a n ; p r o c e d u r e R e g W r i t e I n t e g e r ( MainKey : I n t e g e r ; SubKey : S t r i n g ; ValName : S t r i n g ; V a l u e : I n t e g e r ) ; p r o c e d u r e R e g W r i t e S t r i n g ( MainKey : I n t e g e r ; SubKey : S t r i n g ; ValName : S t r i n g ; V a l u e : S t r i n g ) ;

3.8. MF Library
6

10

12

14

16

18

3.8.10. System
3.8.10.1. Constants SW_HIDE SW_SHOWNORMAL SW_NORMAL SW_SHOWMINIMIZED SW_SHOWMAXIMIZED SW_MAXIMIZE SW_SHOWNOACTIVE SW_SHOW SW_MINIMIZE SW_SHOWMINNOACTIVE

Release Candidate 2

f u n c t i o n Crop ( S : S t r i n g ; Len : I n t e g e r ; D i r : I n t e g e r ; Delimiter : String ) f u n c t i o n F o r E a c h ( L i s t : T S t r i n g L i s t ; Func : S t r i n g ; F l a g : I n t e g e r ) : Boolean ; p r o c e d u r e FormatColumns ( L i s t : T S t r i n g L i s t ; D e l i m i t e r : S t r i n g ; Space : S t r i n g ; Adjustment : I n t e g e r ) ; f u n c t i o n GetCRC32FromString ( S : S t r i n g ) : I n t e g e r ; function GetStringFromList ( List : TStringList ; Delimiter : String ) : String ; function GetTokenList (S : String ; Delimiter : String ; Repeater : Boolean ; I g n o r e F i r s t : Boolean ; I g n o r e L a s t : Boolean ) : T S t r i n g L i s t ; f u n c t i o n IncWC ( S : S t r i n g ; WC: S t r i n g ; Case : B o o l e a n ) : String ; f u n c t i o n Num2Text (Num : I n t e g e r ) : S t r i n g ; f u n c t i o n OEM2ANSI ( S : S t r i n g ) : S t r i n g ; f u n c t i o n Ord ( Char : S t r i n g ) : I n t e g e r ; f u n c t i o n PosX ( S u b S t r : S t r i n g ; S : S t r i n g ) : I n t e g e r ; f u n c t i o n S t r i n g O f C h a r ( Ch : S t r i n g ; Count : I n t e g e r ) : S t r i n g ; f u n c t i o n TestWC ( S : S t r i n g ) : I n t e g e r ; f u n c t i o n T r a n s l a t e ( S : S t r i n g ; Out : S t r i n g ; In : S t r i n g ; P l a c e : S t r i n g ; Case : B o o l e a n ) : S t r i n g ;

101

3. DWS II Standard Libraries SW_SHOWNA SW_RESTORE

EWX_LOGOFF EWX_SHUTDOWN EWX_REBOOT EWX_FORCE EWX_POWEROFF EWX_FORCEIFHUNG

Message-Constants for PostMessage() and SendMessage(): WM_MOVE WM_SIZE WM_ACTIVATE WM_SETFOCUS WM_KILLFOCUS WM_ENABLE WM_CLOSE WM_QUIT WM_SHOWWINDOW WM_ACTIVATEAPP WM_SETCURSOR WM_MOUSEACTIVATE WM_CHILDACTIVATE WM_HELP WM_COMMAND WM_SYSCOMMAND WM_HSCROLL WM_VSCROLL WM_MOUSEMOVE WM_LBUTTONDOWN WM_LBUTTONUP

102

Release Candidate 2

SW_SHOWDEFAULT

3.8. MF Library WM_LBUTTONDBLCLK WM_RBUTTONDOWN WM_RBUTTONUP WM_RBUTTONDBLCLK WM_MBUTTONDOWN WM_MBUTTONUP WM_MBUTTONDBLCLK WM_MOUSEWHEEL WM_MDITILE WM_MDICASCADE WM_CUT WM_COPY WM_PASTE WM_CLEAR WM_UNDO WM_USER BM_CLICK BM_GETCHECK BM_SETCHECK BST_CHECKED BST_INDETERMINATE BST_UNCHECKED CB_GETCOUNT CB_GETCURSEL CB_GETDROPPEDSTATE CB_GETEDITSEL CB_GETTOPINDEX CB_RESETCONTENT CB_SETCURSEL CB_SETEDITSEL CB_SETTOPINDEX CB_SHOWDROPDOWN EM_GETSEL EM_SETSEL

Release Candidate 2

103

3. DWS II Standard Libraries EM_UNDO LB_GETCOUNT LB_GETCURSEL LB_GETSELCOUNT LB_GETTEXT LB_GETTEXTLEN LB_GETTOPINDEX LB_ITEMFROMPOINT LB_RESETCONTENT LB_SELITEMRANGE LB_SETCURSEL LB_SETSEL LB_SETTOPINDEX SB_BOTTOM SB_ENDSCROLL SB_LINEDOWN SB_LINEUP SB_PAGEDOWN SB_PAGEUP SB_THUMBPOSITION SB_THUMBTRACK SB_TOP 3.8.10.2. Functions Listing 3.23: Standard Library: MFLib - System
function ShellExecute ( Operation : String ; Filename : String ; P a r a m e t e r s : S t r i n g ; D i r e c t o r y : S t r i n g ; ShowCmd : I n t e g e r ) : Integer ; function ShellExecuteWait ( Filename : String ; Parameters : S t r i n g ; D i r e c t o r y : S t r i n g ; ShowCmd : I n t e g e r ) : B o o l e a n ; f u n c t i o n ExitWindowsEx ( F l a g s : I n t e g e r ) : I n t e g e r ; f u n c t i o n W r i t e M a i l s l o t ( Machine : S t r i n g ; M a i l s l o t : S t r i n g ; Text : String ) : Boolean ; function GetProcessList : TStringList ; f u n c t i o n HiWord ( V a l u e : I n t e g e r ) : I n t e g e r ;

104

Release Candidate 2

LB_GETSEL

3.8. MF Library
f u n c t i o n I s F i l e A c t i v e ( FileName : S t r i n g ) : B o o l e a n ; f u n c t i o n K i l l P r o c e s s ( Window : I n t e g e r ; FileName : S t r i n g ; K i l l A l l : Boolean ) : Boolean ; f u n c t i o n LoWord ( V a l u e : I n t e g e r ) : I n t e g e r ; f u n c t i o n MakeLong ( Low , High : I n t e g e r ) : I n t e g e r ; f u n c t i o n P o s t M e s s a g e ( Window , Msg , WParam , LParam : I n t e g e r ) : Boolean ; p r o c e d u r e SendKeys ( Keys : S t r i n g ) ; p r o c e d u r e SendKeysEx ( Keys : S t r i n g ; Wait : I n t e g e r ) ; f u n c t i o n SendKeysNamedWin ( Window : S t r i n g ; Keys : S t r i n g ) : Integer ; f u n c t i o n SendKeysNamedWinEx ( Window : S t r i n g ; Keys : S t r i n g ; Wait : I n t e g e r ; Back : B o o l e a n ) : I n t e g e r ; f u n c t i o n SendKeysWin ( Window : I n t e g e r ; Keys : S t r i n g ) : Integer ; f u n c t i o n SendKeysWinEx ( Window : I n t e g e r ; Keys : S t r i n g ; Wait : I n t e g e r ; Back : B o o l e a n ) : I n t e g e r ; f u n c t i o n SendMessage ( Window , Msg , WParam , LParam : I n t e g e r ) : Integer ;

12

14

16

18

3.8.11. Window
3.8.11.1. Functions

Listing 3.24: Standard Library: MFLib - Window


f u n c t i o n FindWindow ( C l a s s : S t r i n g ; Window : S t r i n g ) : I n t e g e r ; f u n c t i o n FindWindowEx ( P a r e n t : I n t e g e r ; C h i l d A f t e r : I n t e g e r ; C l a s s : S t r i n g ; Window : S t r i n g ) : I n t e g e r ; f u n c t i o n GetClassName ( Window : I n t e g e r ) : S t r i n g ; f u n c t i o n GetWindowText ( Window : I n t e g e r ) : S t r i n g ; procedure HideTaskbar ; f u n c t i o n I s I c o n i c ( Window : I n t e g e r ) : B o o l e a n ; f u n c t i o n IsWindow ( Window : I n t e g e r ) : B o o l e a n ; f u n c t i o n IsWindowEnabled ( Window : I n t e g e r ) : B o o l e a n ; f u n c t i o n I s W i n d o w V i s i b l e ( Window : I n t e g e r ) : B o o l e a n ; f u n c t i o n IsZoomed ( Window : I n t e g e r ) : B o o l e a n ; f u n c t i o n SearchWindow ( var C l a s s ; var Window : S t r i n g ; P r o c I D : Integer ) : Integer ; f u n c t i o n SearchWindowEx ( P a r e n t : I n t e g e r ; C h i l d A f t e r : I n t e g e r ; var C l a s s ; var Window : S t r i n g ; Num : I n t e g e r ) : Integer ; p r o c e d u r e ShowTaskbar ;

10

12

Release Candidate 2

10

105

3. DWS II Standard Libraries


14

18

20

3.8.12. dws2MFZipLib
3.8.12.1. Constants Zip_Add Zip_Move Zip_Update Zip_Freshen Zip_Extract Zip_Test Zip_OverwriteConrm Zip_OverwriteAlways Zip_OverwriteNever Zip_EraseFinal Zip_EraseAllowUndo

106

Release Candidate 2

16

f u n c t i o n WaitForWindow ( var C l a s s ; var Window : S t r i n g ; Timeout : I n t e g e r ; ProcID : I n t e g e r ) : I n t e g e r ; f u n c t i o n WaitForWindowClose ( Window : I n t e g e r ; T i m e o u t : I n t e g e r ) : Boolean ; f u n c t i o n WaitForWindowClose ( C l a s s : S t r i n g ; Window : S t r i n g ; Timeout : I n t e g e r ; ProcID : I n t e g e r ) : Boolean ; f u n c t i o n WaitForWindowEnabled ( Window : I n t e g e r ; T i m e o u t : I n t e g e r ) : Boolean ; f u n c t i o n WaitForWindowEnabled ( C l a s s : S t r i n g ; Window : S t r i n g ; Timeout : I n t e g e r ; ProcID : I n t e g e r ) : Boolean ; f u n c t i o n WaitForWindowEx ( P a r e n t : I n t e g e r ; var C l a s s ; var Window : S t r i n g ; T i m e o u t : I n t e g e r ; Num : I n t e g e r ) : I n t e g e r ; p r o c e d u r e WindowMove ( Window : I n t e g e r ; X : I n t e g e r ; Y : I n t e g e r ; Abs : B o o l e a n ) ; p r o c e d u r e WindowResize ( Window : I n t e g e r ; X : I n t e g e r ; Y : I n t e g e r ; Abs : B o o l e a n ) ;

3.8. MF Library 3.8.12.2. Classes Listing 3.25: Standard Library: MFLib - Zip
{ Classes } type TZip = c l a s s f u n c t i o n Add ( A c t i o n : I n t e g e r ; Z i p F i l e : S t r i n g ; FileName : S t r i n g ) : I n t e g e r ; function AddList ( Action : I n t e g e r ; Z i p F i l e : String ; FileNames : T S t r i n g L i s t ) : I n t e g e r ; constructor Create ; f u n c t i o n D e l e t e ( Z i p F i l e : S t r i n g ; FileName : S t r i n g ) : Integer ; f u n c t i o n D e l e t e L i s t ( Z i p F i l e : String ; FileNames : TStringList ) : Integer ; destructor Destroy ; function E x t r a c t ( Action : I n t e g e r ; ZipFile : String ; FileName : S t r i n g ; B a s e D i r : S t r i n g ) : I n t e g e r ; function E x t r a c t L i s t ( Action : I n t e g e r ; ZipFile : String ; FileNames : T S t r i n g L i s t ; BaseDir : String ) : Integer ; function List ( ZipFile : String ) : TStringList ; f u n c t i o n Message ( Z i p F i l e : S t r i n g ) : S t r i n g ; f u n c t i o n ReadAddCompLevel : I n t e g e r ; f u n c t i o n ReadAddDirNames : B o o l e a n ; f u n c t i o n ReadAddDiskSpan : B o o l e a n ; f u n c t i o n R ea dA d dD is k Sp an E r a s e : B o o l e a n ; f u n c t i o n ReadAddEncrypt : B o o l e a n ; function ReadAddHiddenFiles : Boolean ; function ReadAddRecurseDirs : Boolean ; function ReadAddSeparateDirs : Boolean ; f u n c t i o n ReadAddZipTime : B o o l e a n ; function ReadConfirmErase : Boolean ; f u n c t i o n R e ad E x tr D i rN a m es : B o o l e a n ; function ReadExtrOverwrite : Boolean ; f u n c t i o n ReadHowToDelete : I n t e g e r ; f u n c t i o n ReadKeepFreeOnDisk1 : I n t e g e r ; f u n c t i o n ReadMaxVolumeSize : I n t e g e r ; f u n c t i o n ReadMinFreeVolumeSize : I n t e g e r ; f u n c t i o n R e a d P as s w o r d : S t r i n g ; f u n c t i o n ReadSFXAskCmdLine : B o o l e a n ; f u n c t i o n ReadSFXAskFiles : B o o l e a n ; f u n c t i o n ReadSFXCaption : S t r i n g ; f u n c t i o n ReadSFXCommandLine : S t r i n g ; function ReadSFXDefaultDir : String ; f u n c t i o n ReadSFXHideOverwriteBox : B o o l e a n ; f u n c t i o n ReadSFXOverwriteMode : I n t e g e r ;

10

12

14

16

18

20

22

24

26

28

30

32

34

36

Release Candidate 2

107

3. DWS II Standard Libraries


38

40

42

44

46

48

50

52

54

56

58

60

62

64

66

68

70

72

74

f u n c t i o n ReadSpan ( S p a n F i l e : S t r i n g ; var Z i p F i l e : String ) : Integer ; f u n c t i o n ReadTemp : S t r i n g ; f u n c t i o n SFX2ZIP ( Z i p F i l e : S t r i n g ) : I n t e g e r ; p r o c e d u r e WriteAddCompLevel ( V a l u e : I n t e g e r ) ; p r o c e d u r e WriteAddDirNames ( V a l u e : B o o l e a n ) ; p r o c e d u r e W ri t eA d d D i s k S p a n ( V a l u e : B o o l e a n ) ; procedure WriteAddDiskSpanErase ( Value : Boolean ) ; procedure WriteAddEncrypt ( Value : Boolean ) ; procedure WriteAddHiddenFiles ( Value : Boolean ) ; procedure WriteAddRecurseDirs ( Value : Boolean ) ; procedure W r i t e A d d S e p a r a t e D i r s ( Value : Boolean ) ; p r o c e d u r e WriteAddZipTime ( V a l u e : B o o l e a n ) ; procedure WriteConfirmErase ( Value : Boolean ) ; procedure WriteExtrDirNames ( Value : Boolean ) ; procedure W r i t e E x t r O v e r w r i t e ( Value : Boolean ) ; p r o c e d u r e WriteHowToDelete ( V a l u e : I n t e g e r ) ; procedure WriteKeepFreeOnDisk1 ( Value : I n t e g e r ) ; p r o c e d u r e WriteMaxVolumeSize ( V a l u e : I n t e g e r ) ; procedure WriteMinFreeVolumeSize ( Value : I n t e g e r ) ; procedure WritePassword ( Value : S t r i n g ) ; p r o c e d u r e WriteSFXAskCmdLine ( V a l u e : B o o l e a n ) ; procedure WriteSFXAskFiles ( Value : Boolean ) ; procedure WriteSFXCaption ( Value : S t r i n g ) ; p r o c e d u r e WriteSFXCommandLine ( V a l u e : S t r i n g ) ; procedure WriteSFXDefaultDir ( Value : S t r i n g ) ; procedure WriteSFXHideOverwriteBox ( Value : Boolean ) ; p r o c e d u r e WriteSFXOverwriteMode ( V a l u e : I n t e g e r ) ; function WriteSpan ( Z i p F i l e : String ; SpanFile : String ) : Integer ; p r o c e d u r e WriteTemp ( V a l u e : S t r i n g ) ; f u n c t i o n ZIP2SFX ( Z i p F i l e : S t r i n g ) : I n t e g e r ; p r o p e r t y AddCompLevel : I n t e g e r read ReadAddCompLevel w r i t e WriteAddCompLevel ; p r o p e r t y AddDirNames : B o o l e a n read ReadAddDirNames w r i t e WriteAddDirNames ; p r o p e r t y AddDiskSpan : B o o l e a n read ReadAddDiskSpan w r i t e W ri t eA d d D i s k S p a n ; p r o p e r t y A d d D i s k S p a n E r a s e : B o o l e a n read R ea dA d dD is k S p a n E r a s e w r i t e W r i t e A d d D i s k S p a n E r a s e ; p r o p e r t y A d d E n c r y p t : B o o l e a n read ReadAddEncrypt w r i t e WriteAddEncrypt ; p r o p e r t y A d d H i d d e n F i l e s : B o o l e a n read ReadAddHiddenFiles write WriteAddHiddenFiles ; p r o p e r t y A d d R e c u r s e D i r s : B o o l e a n read ReadAddRecurseDirs write WriteAddRecurseDirs ; p r o p e r t y A d d S e p a r a t e D i r s : B o o l e a n read ReadAddSeparateDirs write WriteAddSeparateDirs ;

108

Release Candidate 2

3.9. Symbols Library


76

80

82

84

86

88

90

92

3.9. Symbols Library

Listing 3.26: Standard Library: Symbols

Release Candidate 2

78

p r o p e r t y AddZipTime : B o o l e a n read ReadAddZipTime w r i t e WriteAddZipTime ; p r o p e r t y C o n f i r m E r a s e : B o o l e a n read R e a d C o n f i r m E r a s e write WriteConfirmErase ; p r o p e r t y E x t r D i r N a m e s : B o o l e a n read R e a d E x t r D i r N a m e s write WriteExtrDirNames ; p r o p e r t y E x t r O v e r w r i t e : B o o l e a n read R e a d E x t r O v e r w r i t e write WriteExtrOverwrite ; p r o p e r t y HowToDelete : I n t e g e r read ReadHowToDelete w r i t e WriteHowToDelete ; p r o p e r t y KeepFreeOnDisk1 : I n t e g e r read ReadKeepFreeOnDisk1 w r i t e W r i t e K e e p F r e e O n D i s k 1 ; p r o p e r t y MaxVolumeSize : I n t e g e r read ReadMaxVolumeSize w r i t e WriteMaxVolumeSize ; p r o p e r t y M in F re e Vo l um eS i ze : I n t e g e r read ReadMinFreeVolumeSize w r i t e W r i t e M i n F r e e V o l u m e S i z e ; p r o p e r t y P a s s w o r d : S t r i n g read R e a d P a s s w o r d w r i t e WritePassword ; p r o p e r t y SFXAskCmdLine : B o o l e a n read ReadSFXAskCmdLine w r i t e WriteSFXAskCmdLine ; p r o p e r t y S F XA s k F i le s : B o o l e a n read ReadSFXAskFiles write WriteSFXAskFiles ; p r o p e r t y SFXCaption : S t r i n g read ReadSFXCaption w r i t e WriteSFXCaption ; p r o p e r t y SFXCommandLine : S t r i n g read ReadSFXCommandLine w r i t e WriteSFXCommandLine ; p r o p e r t y S F X D e f a u l t D i r : S t r i n g read R e a d S F X D e f a u l t D i r write WriteSFXDefaultDir ; p r o p e r t y SFXHideOverwriteBox : B o o l e a n read ReadSFXHideOverwriteBox w r i t e WriteSFXHideOverwriteBox ; p r o p e r t y SFXOverwriteMode : I n t e g e r read ReadSFXOverwriteMode w r i t e WriteSFXOverwriteMode ; p r o p e r t y Temp : S t r i n g read ReadTemp w r i t e WriteTemp ; end ;

109

3. DWS II Standard Libraries

{ Forward D e c l a r a t i o n s } t y p e TSymbols = c l a s s ; { Enumerations } t y p e TSymbolType = ( stUnknown , s t A r r a y , s t A l i a s , s t C l a s s , s t C o n s t a n t , s t F i e l d , s t F u n c t i o n , stMember , s t P a r a m , stProperty , stRecord , stUnit , s t V a r i a b l e ) ; { Classes } type TSymbols = c l a s s constructor CreateMain ; c o n s t r u c t o r C r e a t e U i d ( Uid : S t r i n g ) ; c o n s t r u c t o r C r e a t e U n i t ( Name : S t r i n g ) ; function Caption : String ; function Description : String ; destructor Destroy ; override ; f u n c t i o n Eof : B o o l e a n ; procedure F i r s t ; f u n c t i o n GetMembers : TSymbols ; f u n c t i o n G e t P a r a m e t e r s : TSymbols ; f u n c t i o n G e t S u p e r C l a s s : TSymbols ; procedure L a s t ; f u n c t i o n L o c a t e ( Name : S t r i n g ) : B o o l e a n ; f u n c t i o n Name : S t r i n g ; p r o c e d u r e Next ; procedure P r e v i o u s ; f u n c t i o n SymbolType : TSymbolType ; end ;

10

12

14

16

18

20

22

24

26

3.10. Web Library

The DWS2-Web-Library brings you 3 components for building web applications with DWS2 and 1 for desktop script handling (e.g. in reports...), namely dws2Pageloader.

110

Release Candidate 2

3.10. Web Library The Web Library has the ability to automatically check access to a web script. This is accomplished by special naming of the script les: _S<name>.dws means that a user must have a valid user session to be able to access the script _L<name>.dws means that a user must have a valid Login state to access the script _M<name>.dws same as _L<name>.dws, but disallows access with GUEST login state.

N OTE

3.10.1. dws2PageProducer

The dws2PageProducer is based on CustomContentProducer, with standard interface to be called by webactions and return content from scriptles.

3.10.2. dws2PageLoader

This component is similar to the dws2PageProducer but without interface to webbroker.

3.10.3. dws2SessionLib
Dws2SessionLib provides HTTP - usertracking and the ability to store sessiondata. You can nd a very simple Session Tracking Server in the dws2\Libraries\WebLib\SimpleSessionServer directory. Its a CLX based demo that shows how you can add external session tracking to DWS II enabled CGI executables. In normal operational mode, dws2SessionLib does an internal user session tracking. This technique only works in ISAPI modules, because the module is loaded once and if a request hits the module, just a new thread is created that has access to a global internal session list. If you plan to use DWS II enabled CGI executables and you need session tracking, then you need to install an external Session Tracking Server, as the CGI executable terminates after each web-request, thereby clearing the global session list.

H INT

Listing 3.27: Standard Library: WebLib - SessionLib

Release Candidate 2

111

3. DWS II Standard Libraries


{ Constants } const dwstateGLI : I n t e g e r = 1 ; c o n s t dwstateLOFF : I n t e g e r = 1 ; c o n s t dwstateNAT : I n t e g e r = 1 2 ; const dwstateNLI : I n t e g e r = 0 ; const dwstatePRF : I n t e g e r = 9 ; const dwstateSU : I n t e g e r = 1 0 0 ; c o n s t dwstateTOUT : i n t e g e r = 2 ; const dwstateULI : I n t e g e r = 1 0 ; const dwstateVIP : I n t e g e r = 2 0 ; c o n s t V e r s i o n : S t r i n g = 2.1.2001.6.20 ; { Classes } type Session = c l a s s ( TObject ) class function GetActiveUsers : Integer ; c la s s function GetCState : I n t e g e r ; c l a s s f u n c t i o n GetIpAddr : String ; c l a s s f u n c t i o n GetSBrand : S t r i n g ; c l a s s f u n c t i o n G e t T L a s t A c t i o n : DateTime ; c l a s s f u n c t i o n GetTLogin : DateTime ; c l a s s f u n c t i o n Param ( Name : s t r i n g ) : v a r i a n t ; c l a s s procedure S e t C S t a t e ( Value : I n t e g e r ) ; c l a s s procedure SetIpAddr ( Value : S t r i n g ) ; c l a s s procedure SetSBrand ( Value : S t r i n g ) ; c l a s s p r o c e d u r e S e t T L a s t A c t i o n ( V a l u e : DateTime ) ; c l a s s p r o c e d u r e S e t T L o g i n ( V a l u e : DateTime ) ; c l a s s p r o c e d u r e S t o r e ( name : s t r i n g ; v a l u e : v a r i a n t ) ; p r o p e r t y A c t i v e U s e r s : I n t e g e r read G e t A c t i v e U s e r s ; p r o p e r t y C l i e n t S t a t e : I n t e g e r read G e t C S t a t e w r i t e SetCState ; p r o p e r t y I p A d d r : S t r i n g read G e t I p A d d r w r i t e S e t I p A d d r ; p r o p e r t y SBrand : S t r i n g read G e t S b r a n d w r i t e S e t S b r a n d ; p r o p e r t y T L a s t A c t i o n : DateTime read G e t T L a s t A c t i o n write SetTLastAction ; p r o p e r t y TLogin : DateTime read G e t T l o g i n w r i t e SetTlogin ; end ; { Functions } f u n c t i o n TIDfunc : S t r i n g ; forward ; f u n c t i o n A c t i v e S e s s i o n : b o o l e a n ; forward ; f u n c t i o n URL(AnURL : S t r i n g ) : S t r i n g ; forward ;

10

12

14

16

18

20

22

24

26

28

30

32

34

36

38

40

112

Release Candidate 2

3.10. Web Library

3.10.4. dws2WebLib
Dws2WebLib introduces some classes to handle the ISAPI calls of Borlands webbroker (request, response, cookie), the scriptdoc class to store information about the scriptle, and TFormVarGroup to handle multiple input elds of database tables in html forms. There are also some "functions" useful for webapps. Listing 3.28: Standard Library: WebLib
{ Forward D e c l a r a t i o n s } t y p e TCookie = c l a s s ; { Classes type Request class class class class class class class class class class class class class class class class class class class class class class class class class class class end ; }

10

12

14

16

18

20

22

24

26

28

30

32

= c l a s s ( TObject ) function Accept : String ; function Authorization : string ; function Content : String ; function ContentLength : I n t e g e r ; function ContentType : String ; f u n c t i o n C o o k i e ( Name : S t r i n g ) : S t r i n g ; f u n c t i o n CookieCount : I n t e g e r ; f u n c t i o n CookieName ( Index : I n t e g e r ) : S t r i n g ; f u n c t i o n C o o k i e V a l u e ( Index : I n t e g e r ) : S t r i n g ; f u n c t i o n Date : DateTime ; f u n c t i o n From : S t r i n g ; f u n c t i o n Host : S t r i n g ; function LogContent : String ; f u n c t i o n Method : S t r i n g ; f u n c t i o n Param ( Name : S t r i n g ) : S t r i n g ; f u n c t i o n ParamCount : I n t e g e r ; f u n c t i o n ParamName ( Index : I n t e g e r ) : S t r i n g ; f u n c t i o n Params ( Name : S t r i n g ) : S t r i n g ; f u n c t i o n ParamValue ( Index : I n t e g e r ) : s t r i n g ; function PathInfo : String ; function Referer : String ; f u n c t i o n RemoteAddr : S t r i n g ; f u n c t i o n RemoteHost : S t r i n g ; function ScriptName : String ; function T i t l e : String ; function Url : String ; f u n c t i o n UserAgent : String ;

34

36

38

40

type Response = c l a s s ( TObject ) c l a s s f u n c t i o n C o o k i e ( Index : I n t e g e r ) : TCookie ; c l a s s f u n c t i o n CookieByName ( Name : S t r i n g ) : TCookie ; c l a s s f u n c t i o n CookieCount : I n t e g e r ;

Release Candidate 2

113

3. DWS II Standard Libraries


c l a s s f u n c t i o n GetAllow : S t r i n g ; c l a s s function GetContent : String ; c l a s s function GetContentEncoding : String ; c l a s s function GetContentLength : I n t e g e r ; c l a s s function GetContentType : String ; class function GetContentVersion : String ; c l a s s f u n c t i o n G e t D a t e : DateTime ; c l a s s f u n c t i o n GetDerivedFrom : String ; c l a s s f u n c t i o n G e t E x p i r e s : DateTime ; c l a s s f u n c t i o n G e t L a s t M o d i f i e d : DateTime ; class function GetLocation : String ; c l a s s f u n c t i o n GetLogMessage : S t r i n g ; c l a s s f u n c t i o n GetRealm : S t r i n g ; class function GetReasonString : String ; class function GetServer : String ; c la s s function GetStatusCode : I n t e g e r ; class function GetTitle : String ; c l a s s function GetVersion : String ; c l a s s f u n c t i o n NewCookie : TCookie ; c l a s s procedure S e n d R e d i r e c t ( Uri : S t r i n g ) ; c l a s s procedure SetAllow ( Value : S t r i n g ) ; c l a s s procedure S e t C o n t e n t ( Value : S t r i n g ) ; c l a s s procedure S e t C o n t e n t E n c o d i n g ( Value : S t r i n g ) ; c l a s s procedure S e t C o n t e n t L e n g t h ( Value : I n t e g e r ) ; c l a s s procedure SetContentType ( Value : S t r i n g ) ; c l a s s procedure S e t C o n t e n t V e r s i o n ( Value : S t r i n g ) ; c l a s s p r o c e d u r e S e t D a t e ( V a l u e : DateTime ) ; c l a s s procedure SetDerivedFrom ( Value : S t r i n g ) ; c l a s s p r o c e d u r e S e t E x p i r e s ( V a l u e : DateTime ) ; c l a s s p r o c e d u r e S e t L a s t M o d i f i e d ( V a l u e : DateTime ) ; c l a s s procedure S e t L o c a t i o n ( Value : S t r i n g ) ; c l a s s procedure SetLogMessage ( Value : S t r i n g ) ; c l a s s procedure SetRealm ( Value : S t r i n g ) ; c l a s s procedure S e t R e a s o n S t r i n g ( Value : S t r i n g ) ; c l a s s procedure S e t S e r v e r ( Value : S t r i n g ) ; c l a s s procedure S e t S t a t u s C o d e ( Value : I n t e g e r ) ; c l a s s procedure S e t T i t l e ( Value : S t r i n g ) ; c l a s s procedure S e t V e r s i o n ( Value : S t r i n g ) ; p r o p e r t y Allow : S t r i n g read GetAllow w r i t e S e t A l l o w ; p r o p e r t y C o n t e n t : S t r i n g read G e t C o n t e n t w r i t e SetContent ; p r o p e r t y C o n t e n t E n c o d i n g : S t r i n g read GetContentEncoding write SetContentEncoding ; p r o p e r t y C o n t e n t L e n g t h : I n t e g e r read G e t C o n t e n t L e n g t h write SetContentLength ; p r o p e r t y C o n t e n t T y p e : S t r i n g read G e t C o n t e n t T y p e w r i t e SetContentType ; p r o p e r t y C o n t e n t V e r s i o n : S t r i n g read G e t C o n t e n t V e r s i o n write SetContentVersion ;

42

44

46

48

50

52

54

56

58

60

62

64

66

68

70

72

74

76

78

80

82

84

114

Release Candidate 2

3.10. Web Library


p r o p e r t y Date : DateTime read G e t D a t e w r i t e S e t D a t e ; p r o p e r t y D e r i v e d F r o m : S t r i n g read G e t D e r i v e d F r o m w r i t e SetDerivedFrom ; p r o p e r t y E x p i r e s : DateTime read G e t E x p i r e s w r i t e SetExpires ; p r o p e r t y L a s t M o d i f i e d : DateTime read G e t L a s t M o d i f i e d write SetLastModified ; p r o p e r t y L o c a t i o n : S t r i n g read G e t L o c a t i o n w r i t e SetLocation ; p r o p e r t y LogMessage : S t r i n g read GetLogMessage w r i t e S e tL o g M e s sa g e ; p r o p e r t y Realm : S t r i n g read GetRealm w r i t e S e t R e a l m ; p r o p e r t y R e a s o n S t r i n g : S t r i n g read G e t R e a s o n S t r i n g write SetReasonString ; p r o p e r t y S e r v e r : S t r i n g read G e t S e r v e r w r i t e S e t S e r v e r ; p r o p e r t y S t a t u s C o d e : I n t e g e r read G e t S t a t u s C o d e w r i t e SetStatusCode ; p r o p e r t y T i t l e : S t r i n g read G e t T i t l e w r i t e S e t T i t l e ; p r o p e r t y V e r s i o n : S t r i n g read G e t V e r s i o n w r i t e SetVersion ; end ; type ScriptDoc = c l a s s ( TObject ) c l a s s f u n c t i o n Date : DateTime ; c l a s s f u n c t i o n FileName : S t r i n g ; c l a s s function Path : String ; class function Size : Integer ; end ; type TCookie = c l a s s ( T O b j e c t ) f u n c t i o n GetDomain : S t r i n g ; f u n c t i o n G e t E x p i r e s : DateTime ; function GetHeaderValue : String ; f u n c t i o n GetName : S t r i n g ; function GetPath : String ; function GetSecure : Boolean ; function GetValue : String ; p r o c e d u r e SetDomain ( V a l u e : S t r i n g ) ; p r o c e d u r e S e t E x p i r e s ( V a l u e : DateTime ) ; p r o c e d u r e SetName ( V a l u e : S t r i n g ) ; procedure S e t P a t h ( Value : S t r i n g ) ; procedure S e t S e c u r e ( Value : Boolean ) ; procedure SetValue ( Value : S t r i n g ) ; p r o p e r t y Domain : S t r i n g read GetDomain w r i t e SetDomain ; p r o p e r t y E x p i r e s : DateTime read G e t E x p i r e s w r i t e SetExpires ; p r o p e r t y H e a d e r V a l u e : S t r i n g read G e t H e a d e r V a l u e ;

86

88

90

92

94

96

98

100

102

104

106

108

110

112

114

116

118

120

122

124

Release Candidate 2

115

3. DWS II Standard Libraries


property property property ; property end ; Name : S t r i n g read GetName w r i t e SetName ; P a t h : S t r i n g read G e t P a t h w r i t e S e t P a t h ; S e c u r e : B o o l e a n read G e t S e c u r e w r i t e S e t S e c u r e

126

130

132

134

136

138

140

142

144

146

type TFormVarGroup = c l a s s ( T O b j e c t ) constructor Create ; function count : i n t e g e r ; f u n c t i o n Eof : b o o l e a n ; f u n c t i o n Ext : S t r i n g ; procedure F i r s t ; function GetAddNullFields : boolean ; function GetPrefix : String ; p r o c e d u r e Next ; f u n c t i o n RecNr : i n t e g e r ; procedure S e t A d d N u l l F i e l d s ( Value : boolean ) ; procedure S e t P r e f i x ( P r e f i x : S t r i n g ) ; f u n c t i o n Value : S t r i n g ; p r o p e r t y A d d N u l l F i e l d s : b o o l e a n read G e t A d d N u l l F i e l d s write SetAddNullFields ; p r o p e r t y P r e f i x : S t r i n g read G e t P r e f i x w r i t e S e t P r e f i x ; end ; { Functions } f u n c t i o n FormVar ( ParamName : S t r i n g ) : S t r i n g ; forward ; f u n c t i o n RtfToHtml ( R t f S t r : S t r i n g ) : S t r i n g ; forward ; f u n c t i o n TrimURL ( sURL : S t r i n g ) : S t r i n g ; forward ; f u n c t i o n AcceptWML : b o o l e a n ; forward ; f u n c t i o n URLencode ( sURL : S t r i n g ) : S t r i n g ; forward ; f u n c t i o n URLdecode ( sURL : S t r i n g ) : S t r i n g ; forward ; p r o c e d u r e _ f o r w a r d ( NewFile : S t r i n g ) ; forward ;

148

150

152

154

156

116

Release Candidate 2

128

V a l u e : S t r i n g read G e t V a l u e w r i t e S e t V a l u e ;

The DWS II installation package also ships some non standard libraries. These libraries will not be covered by this document. Just that you get an idea which libraries are currently considered non standard, well list some of them here.

4.1. ADO Library

For more information regarding this library (especially the functions and classes the library exports) please have a look at the HTML documentation.

4.2. DB Library
Consider this library as deprecated.

4.3. SMTP Library (D5, D6 only)

Since Delphi 7, Borland does not ship the FastNet components with Delphi. This library is deprecated and no longer maintained.

Release Candidate 2

4. Non DWS II Standard Libraries

117

4. Non DWS II Standard Libraries

118

Release Candidate 2

Part III.

Advanced Topics

Release Candidate 2

119

Release Candidate 2

Future versions of this document may ll up this chapter. For now it can be considered as a placeholder.

Release Candidate 2

5. DWS II Tools

121

5. DWS II Tools

122

Release Candidate 2

Figure 6.1 on the next page shows the WebModule of the ISAPI Demo. Well use this example to show how a DWS II ISAPI module has to be installed and how you can use it afterwards. We wont cover topics as How to setup IIS for debugging here.

6.1. Installation of the ISAPI Demo


If youve compiled the demo, and run IIS on your computer, follow the steps given in section 6.1.1. In case youve installed Apache 2.x (Windows), follow the steps in section 6.1.2. N OTE

You can not run this demo under Linux, because its an ISAPI module.

6.1.1. Using IIS


Copy the dws2.dll le to the scripts directory of your server. Open the dws2\Demos directory in explorer, select the ISAPI subdirectory and press right mouse key. In the context menu, youll nd a menu item that allows you to publish the directory via the IIS. If you chose IsapiDemo as the virtual directory name on the server, you should be able to run the index.dws script by typing following URL in your browser: http://localhost/scripts/dws2. dll/IsapiDemo/index.dws

6.1.2. Using Apache 2.0


Only for Win32 Platform! (Provided by Kenneth Wilcox <k3nx@hotmail.com> ) Copy the dws2.dll to the cgi-bin directory on the server and make the following changes to the httpd.conf le: AddType application/x-httpd-dws .dws Action application/x-httpd-dws "/cgi-bin/dws2.dll" AddHandler isapi-isa .dll

Release Candidate 2

6. Creating Web Applications Using DWS II 2.0

123

6. Creating Web Applications Using DWS II 2.0

Figure 6.1.: ISAPI Demo - WebModule

ISAPICacheFile "C:/Program Files/Apache Group/Apache2/cgi-bin/dws2.dll" If you place the dll in any other directory make sure that it is aliased and that it has ExecCGI permissions on it. Line 1 tells Apache to set all .dws les to application/x-httpd-dws MIME type Line 2 tells Apache that all application/x-httpd-dws MIME les are to be sent to dws2.dll for processing Line 3 tells Apache that .dll les are ISAPI extentions Line 4 tells Apache to load dws2.dll and keep it loaded (if this line is omitted then Apache will load/unload the ISAPI with each request)

6.2. Other demos..


Demos for Linux may follow in another version of the document.

124

Release Candidate 2

The authors of this document would be glad, if some DWS II community members could provide short How-Tos that could be included here. TIA!

7.1. Working with Objects

7.1.1. In Delphi, Get the Reference to a Delphi Object that is Wrapped by a Script Object
Use the GetExternalObjForID function dened in dws2comp.pas. It has the following denition:
function GetExternalObjForID(Info : TProgramInfo; const AVarName: string) : TObject;

7.2. Working with DWS2Unit

7.2.1. In DWS, Use Functions/Procedures/Objects Dened in other Dws2Units


Use the Dependencies property of the Tdws2Unit component (newline-separated names of used units).

7.3. Working with Scripts


7.3.1. In DWS, Emulate Dynamic Arrays
The dynamic arrays of DWSII 2.0 are in fact quite static. The only way to create a dynamic array is to declare an array constant. The compiler allocates space on the stack for this constants right below the regular stack. Because of this method there cant be a SetLength because it would mean that the regular stack would have to be moved at runtime. As long as there is not memory manager in DWSII we dont see a better way to handle this. There are mainly two work-arounds: 1. Use a TList 2. If you can use the COMConnector, try:

Release Candidate 2

7. How-To

125

7. How-To Listing 7.1: HowTo: Emulate Dynmic Arrays


var A : C o m V a r i a n t A r r a y ; A . High : = 3 ; / / s e t d i m e n s i o n A[ 0 ] : = 1 0 ; A[ 1 ] : = 2 0 ; A [ 2 ] : = DWS ; A [ 3 ] : = Array ; var i : I n t e g e r ; f o r i : = A . Low t o A . High do begin p r i n t l n (A[ i ] ) ; end ; p r i n t l n (A . Low ) ; p r i n t l n (A . High ) ; p r i n t l n (A . Length ) ;

10

12

14

7.3.2. In Delphi, Detect if a Variable is Used During the Running of the Script
In DWS, all variables are initialized i.e. a variable is dened immediately after the var-statement is executed. One workaround is to assign a never-used value during the variable assignment, and test for that instead e.g. Listing 7.2: HowTo: Detect Variable Usage
var I : I n t e g e r = 9 9 9 9 ; i f I = 9999 then / / u n d e f i n e d or something

126

Release Candidate 2

Release Candidate 2

8. Appendices

127

8. Appendices

128

Release Candidate 2

2.1. 2.2. 2.3. 2.4. 2.5. 2.6. 2.7. 2.8. 2.9. 2.10. 2.11. 3.1. 3.2. 3.3. 3.4. 3.5. 3.6. 3.7. 3.8. 3.9. 3.10. 3.11. 3.12. 3.13. 3.14. 3.15. 3.16. 3.17. 3.18. 3.19. 3.20. 3.21. 3.22. 3.23. 3.24.

SimpleDemo EventHandler code . . . . . . . . . . . . . . . . CallDemo: calling Test1 . . . . . . . . . . . . . . . . . . . . CallDemo: calling Test4 . . . . . . . . . . . . . . . . . . . . DWSIISyntax: Differences to Delphi . . . . . . . . . . . . . . DWSIISyntax: Nested Declaration . . . . . . . . . . . . . . . Working with Delphi objects in DWSII: TWindow . . . . . . Working with Delphi objects in DWSII: TWindow Constructor Working with Delphi objects in DWSII: TWindow SetPosition Working with Delphi objects in DWSII: TWindow Update . . Advanced Techniques: Get ScriptObject in OnEval . . . . . . Advanced Techniques: IScriptObj denition . . . . . . . . . . Connectors: COM . . . . . . . . . . . . . . . . . . . . . . . . Internal Functions: Maths . . . . . . . . . . . . . . . . . . . . Internal Functions: String Functions . . . . . . . . . . . . . . Internal Functions: DateTime Functions . . . . . . . . . . . . Internal Functions: Variant Functions . . . . . . . . . . . . . Internal Functions: File Functions . . . . . . . . . . . . . . . Internal Functions: GUI Functions . . . . . . . . . . . . . . . Internal Functions: Global Variable Functions . . . . . . . . . Strings Unit: Functions . . . . . . . . . . . . . . . . . . . . . Standard Library: Classes Library . . . . . . . . . . . . . . . Standard Library: IBX / IBO Library . . . . . . . . . . . . . . Standard Library: IBX / IBO Library - DataSetGrp Example . Standard Library: Fiber . . . . . . . . . . . . . . . . . . . . . Standard Library: Ini . . . . . . . . . . . . . . . . . . . . . . Standard Library: MFLib - Basic . . . . . . . . . . . . . . . . Standard Library: MFLib - Connection . . . . . . . . . . . . . Standard Library: MFLib - Dialog . . . . . . . . . . . . . . . Standard Library: MFLib - File . . . . . . . . . . . . . . . . . Standard Library: MFLib - Info . . . . . . . . . . . . . . . . Standard Library: MFLib - Registry . . . . . . . . . . . . . . Standard Library: MFLib - Shell . . . . . . . . . . . . . . . . Standard Library: MFLib - String . . . . . . . . . . . . . . . Standard Library: MFLib - System . . . . . . . . . . . . . . . Standard Library: MFLib - Window . . . . . . . . . . . . . .

Release Candidate 2

Listings

. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

23 27 27 32 33 36 37 40 41 41 42 46 47 55 62 67 71 76 79 82 83 87 91 92 93 95 95 95 96 98 99 100 100 104 105

129

Listings 3.25. 3.26. 3.27. 3.28. 7.1. 7.2. Standard Library: MFLib - Zip . . . . . Standard Library: Symbols . . . . . . . Standard Library: WebLib - SessionLib Standard Library: WebLib . . . . . . . HowTo: Emulate Dynmic Arrays . . . . HowTo: Detect Variable Usage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 107 109 111 113 126 126

130

Release Candidate 2

1.1. 1.2. 1.3. 1.4. 2.1. 2.2. 2.3. 2.4. 2.5.

DWS root in CVS . . . . . . . . . . . dws2 module, directory layout . . . dws2tools module - directory tree . dws2 core (above: VCL; below: CLX)

Release Candidate 2
. . . . . . . .

List of Figures

. . . .

. . . .

. . . .

. . . .

. . . .

. . . .

. . . .

. . . .

. . . .

. . . .

. . . .

. . . .

. . . .

. . . . . . . . .

. . . . . . . . .

. . . . . . . . .

. . . . . . . . .

. . . . . . . . .

. . . . . . . . .

. . . . . . . . .

15 17 22 22 24 26 35 38 39 45

SimpleDemo Output . . . . . . . . . . . . . . . . . . . . . . . . Call Demo - Design-time . . . . . . . . . . . . . . . . . . . . . . Object TreeView of the dws2Unit component found in Basic demo Object TreeView of the TWindow class dened by dws2Unit . . . Object Inspector: TWindow Constructor . . . . . . . . . . . . . .

3.1. DWS II tab with Common Libraries installed . . . . . . . . . . . . . . . . . .

6.1. ISAPI Demo - WebModule . . . . . . . . . . . . . . . . . . . . . . . . . . . . 124

131

List of Figures

132

Release Candidate 2

Release Candidate 2

Index

Abs, 51 AnsiCompareStr, 60 AnsiCompareText, 60 AnsiLowerCase, 58 AnsiUpperCase, 59 AppendStringToFile, 73 ArcCos, 49 ArcCosh, 49 ArcSin, 49 ArcSinh, 49 ArcTan, 50 ArcTanh, 50 ChangeFileExt, 75 CharAt, 58 ChDir, 73 Chr, 58 CleanupGlobalVars, 81 CompareStr, 60 CompareText, 59 Constants MFLib BM_CLICK, 103 BM_GETCHECK, 103 BM_SETCHECK, 103 BST_CHECKED, 103 BST_INDETERMINATE, 103 BST_UNCHECKED, 103 CB_GETCOUNT, 103 CB_GETCURSEL, 103 CB_GETDROPPEDSTATE, 103 CB_GETEDITSEL, 103 CB_GETTOPINDEX, 103 CB_RESETCONTENT, 103 CB_SETCURSEL, 103

CB_SETEDITSEL, 103 CB_SETTOPINDEX, 103 CB_SHOWDROPDOWN, 103 cdrLeft, 100 cdrRight, 100 DRIVE_CDROM, 96 DRIVE_FIXED, 96 DRIVE_NO_ROOT_DIR, 96 DRIVE_RAMDISK, 96 DRIVE_REMOTE, 96 DRIVE_REMOVABLE, 96 DRIVE_UNKNOWN, 96 EM_GETSEL, 103 EM_SETSEL, 103 EM_UNDO, 104 EWX_FORCE, 102 EWX_FORCEIFHUNG, 102 EWX_LOGOFF, 102 EWX_POWEROFF, 102 EWX_REBOOT, 102 EWX_SHUTDOWN, 102 FILEDATE_CREATION, 96 FILEDATE_LASTACCESS, 96 FILEDATE_LASTWRITE, 96 HKEY_CLASSES_ROOT, 99 HKEY_CURRENT_CONFIG, 99 HKEY_CURRENT_USER, 99 HKEY_DYN_DATA, 99 HKEY_LOCAL_MACHINE, 99 HKEY_PERFORMANCE_DATA, 99 HKEY_USERS, 99 LB_GETCOUNT, 104 LB_GETCURSEL, 104 LB_GETSEL, 104

133

Index LB_GETSELCOUNT, 104 LB_GETTEXT, 104 LB_GETTEXTLEN, 104 LB_GETTOPINDEX, 104 LB_ITEMFROMPOINT, 104 LB_RESETCONTENT, 104 LB_SELITEMRANGE, 104 LB_SETCURSEL, 104 LB_SETSEL, 104 LB_SETTOPINDEX, 104 MOVEFILE_COPY_ALLOWED, 96 MOVEFILE_CREATE_HARDLINK, 96 MOVEFILE_DELAY_UNTIL_REBOOT, 96 MOVEFILE_FAIL_IF_NOT_TRACKABLE, 96 MOVEFILE_REPLACE_EXISTING, 96 MOVEFILE_WRITE_THROUGH, 96 SB_BOTTOM, 104 SB_ENDSCROLL, 104 SB_LINEDOWN, 104 SB_LINEUP, 104 SB_PAGEDOWN, 104 SB_PAGEUP, 104 SB_THUMBPOSITION, 104 SB_THUMBTRACK, 104 SB_TOP, 104 SW_HIDE, 101 SW_MAXIMIZE, 101 SW_MINIMIZE, 101 SW_NORMAL, 101 SW_RESTORE, 102 SW_SHOW, 101 SW_SHOWDEFAULT, 102 SW_SHOWMAXIMIZED, 101 SW_SHOWMINIMIZED, 101 SW_SHOWMINNOACTIVE, 101 SW_SHOWNA, 102 SW_SHOWNOACTIVE, 101 SW_SHOWNORMAL, 101 VER_UNKNOWN, 97 VER_WIN2000, 98 VER_WIN32S, 97 VER_WIN95, 97 VER_WIN98, 98 VER_WIN98SE, 98 VER_WINME, 98 VER_WINNT, 98 VER_WINNT4, 98 WM_ACTIVATE, 102 WM_ACTIVATEAPP, 102 WM_CHILDACTIVATE, 102 WM_CLEAR, 103 WM_CLOSE, 102 WM_COMMAND, 102 WM_COPY, 103 WM_CUT, 103 WM_ENABLE, 102 WM_HELP, 102 WM_HSCROLL, 102 WM_KILLFOCUS, 102 WM_LBUTTONDBLCLK, 103 WM_LBUTTONDOWN, 102 WM_LBUTTONUP, 102 WM_MBUTTONDBLCLK, 103 WM_MBUTTONDOWN, 103 WM_MBUTTONUP, 103 WM_MDICASCADE, 103 WM_MDITILE, 103 WM_MOUSEACTIVATE, 102 WM_MOUSEMOVE, 102 WM_MOUSEWHEEL, 103 WM_MOVE, 102 WM_PASTE, 103 WM_QUIT, 102 WM_RBUTTONDBLCLK, 103 WM_RBUTTONDOWN, 103 WM_RBUTTONUP, 103 WM_SETCURSOR, 102 WM_SETFOCUS, 102 WM_SHOWWINDOW, 102 WM_SIZE, 102 WM_SYSCOMMAND, 102 WM_UNDO, 103 WM_USER, 103 WM_VSCROLL, 102

134

Release Candidate 2

Index Zip_Add, 106 Zip_EraseAllowUndo, 106 Zip_EraseFinal, 106 Zip_Extract, 106 Zip_Freshen, 106 Zip_Move, 106 Zip_OverwriteAlways, 106 Zip_OverwriteConrm, 106 Zip_OverwriteNever, 106 Zip_Test, 106 Zip_Update, 106 Contributors, 8 Copy, 61 Cos, 49 Cosh, 49 Cotan, 50 CreateDir, 73 database connectivity standard, 87 Date, 63 DateTimeToStr, 63 DateToStr, 63 DayOfWeek, 65 DecodeDate, 65 DecodeTime, 66 DegToRad, 50 Delete, 58 DeleteFile, 73 dws2Hashtables, 86 dws2UnitEditor, 83 emulate dynamic arrays, 125 EncodeDate, 66 EncodeTime, 66 ErrorDlg, 77 Exp, 51 ExtObject, 40 ExtractFileDir, 74 ExtractFileDrive, 74 ExtractFileExt, 75 ExtractFileName, 74 ExtractFilePath, 75 FileExists, 73 FileSearch, 74 FloatToStr, 57 FormatDateTime, 65 Frac, 51

Release Candidate 2

Garbage Collection, 37 get reference to wrapped Delphi object, 125 GetCurrentDir, 74 Hypot, 54 Inc, 54 IncMonth, 65 InformationDlg, 77 InputBox, 77 Insert, 58 Instances, 40 Int, 51 IntToHex, 57 IntToStr, 57 IsDelimiter, 60 IsLeapYear, 65 LastDelimiter, 60 LeftStr, 61 Length, 59 Ln, 51 load encrypted DWS II scripts, 95 LoadStringFromFile, 73 Log10, 51 Log2, 51 LogN, 51 LowerCase, 58 Max, 52 MidStr, 61 Min, 52 Now, 63 Null, 69 OkCancelDlg, 78 OnAssignExternalObject, 37 Ord, 58 Pi, 50 Pos, 59

135

Index Power, 52 Print, Internal Function, 46 PrintLn, Internal Function, 46 QuestionDlg, 77 QuotedStr, 61 RadToDeg, 50 RandG, 53 Random, 53 RandomInt, 53 Randomize, 53 RandSeed, 53 ReadGlobalVar, 81 ReadGlobalVarDef, 81 RemoveDir, 74 RenameFile, 73 reports, 110 RightStr, 61 Round, 52 save compiled script, 29 SaveStringToFile, 73 Session Tracking Server, 111 SetCharAt, 58 SetCurrentDir, 74 SetLength, 59 SetRandSeed, 53 ShowMessage, 77 Sin, 49 Sinh, 49 Sqr, 51 Sqrt, 51 StringOfChar, 61 StrToDate, 64 StrToDateTime, 63 StrToFloat, 57 StrToFloatDef, 57 StrToInt, 57 StrToIntDef, 57 StrToTime, 65 Tan, 49 Tanh, 49 THashTable, 86 Time, 63 TimeToStr, 64 TIntegerHashTable, 86 Trim, 59 TrimLeft, 59 TrimRight, 59 Trunc, 52 TStringHashTable, 86 Unassigned, 69 UpperCase, 59 use types dened in other dws2Units, 125 VarAsType, 70 VarClear, 69 VarIsEmpty, 69 VarIsNull, 69 VarToStr, 70 WriteGlobalVar, 81

136

Release Candidate 2

You might also like