Patrol Unix Script Language Reference Manual
Patrol Unix Script Language Reference Manual
Version 3.3
April 5, 1999
This document is published by the BMC Software, Inc., Technical Publications Department. Copyright [19971999] BMC Software, Inc. All rights reserved. BMC Software, the BMC Software logos, and all other product or service names are trademarks or registered trademarks of BMC Software, Inc., in the USA and in other select countries. The and indicate USA trademark or USA registration. PATROL SCRIPT LANGUAGE IS PROPRIETARY AND CONFIDENTIAL TO BMC SOFTWARE, INC. All other third-party logos and product/trade names are trademarks or registered trademarks of their respective companies. RESTRICTED RIGHTS LEGEND Use, distribution, or disclosure by the Government is subject to restrictions set forth in subparagraph (c)(1)(ii) of Rights in Technical Data and Computer Software clause in DFARS 252.227-7013. BMC Software, Inc. 2101 CityWest Blvd. Houston, TX 77042-2827 USA
International
Outside the USA and Canada, you can contact a BMC Software international support center: Africa, Europe, Latin America, and the Middle East Asia/Pacific BMC Software, Inc. BMC Software (Australia) Pty. Ltd. 2101 CityWest Blvd. 3rd Floor Houston, TX 77042-2827 290 Burwood Road USA Hawthorn Victoria Telephone: 713 918 8800 Australia Fax: 713 918 1303 Telephone: (61) 3 9810 2010 Fax: (61) 3 9810 2030 You can also call the BMC Software office in your country, if applicable. For a complete list of all BMC Software offices and subsidiaries anywhere in the world, see the BMC Software home page at http://www.bmc.com.
Contents
Contents
About This Manual Chapter 1 PSL Language Overview
What Is PSL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-2 Interpreted PSL Scripts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-2 Compiled PSL Binary Files . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-2 Optimization . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-3 Diagnostics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-3 PSL Built-in Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-3 Locking Functions for Concurrency Control . . . . . . . . . . . . . . . 1-4 Set Functions for PSL Lists . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-4 PSL Mathematical Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-5 PSL Libraries . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-6 PSL Process Synchronization . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-7 PSL Shared Global Channels . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-7 The Need for Shared Global Channels in PSL . . . . . . . . . . . . . . 1-7 The Implementation of PSL Shared Global Channels . . . . . . . . 1-8 The Effect of PSL Shared Global Channel Mechanisms . . . . . . 1-9 How to Use PSL in PATROL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-9 Complex Application Discovery . . . . . . . . . . . . . . . . . . . . . . . . . 1-9 Advanced User Commands . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-10 Efficient Monitoring Parameters . . . . . . . . . . . . . . . . . . . . . . . . . 1-10 How PSL Relates to PATROL Architecture . . . . . . . . . . . . . . . . . . . 1-11 Using Built-in or User-Defined Object Variables . . . . . . . . . . . . . . . 1-13 PSL Naming Conventions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-14
Contents
iii
Chapter 2
PSL Data Types and Objects . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .2-2 Numeric Constants . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .2-2 PSL Variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .2-3 Default Initialization of PSL Variables . . . . . . . . . . . . . . . . . . . .2-3 PSL Predefined Constants . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .2-4 PSL String Literals . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .2-6 PSL Here Documents . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .2-7 ActiveX Scripts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .2-8 PSL Lists . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .2-8 PSL Simple Statements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .2-9 PSL Operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .2-10 Arithmetic Operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .2-10 Assignment Operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .2-11 Increment/Decrement Operators . . . . . . . . . . . . . . . . . . . . . . . . .2-12 Bitwise Operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .2-12 Logical Operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .2-13 Relational Operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .2-14 Shift Operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .2-14 String Operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .2-15 Ternary Operator . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .2-16 PSL Operator Precedence and Associativity . . . . . . . . . . . . . . . .2-17
Chapter 3 PSL Statements
Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .3-2 PSL Compound Statements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .3-2 do...until . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .3-4 exit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .3-6 export . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .3-7 for . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .3-9 foreach . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .3-11 function . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .3-13 The return Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .3-14 Functions with Variable Length Argument Lists . . . . . . . . . . . . .3-15 Defining Local Variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .3-16 Entry Point Function . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .3-17 Start of Execution Without an Entry Point Function . . . . . . . . . .3-18 Backward Compatibility with Earlier PSL Versions . . . . . . . . . .3-19 Limitations of User-Defined Functions . . . . . . . . . . . . . . . . . . . .3-19 if . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .3-21
BMC Software, Inc., Confidential and Proprietary Information
iv
last . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-23 next . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-24 requires . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-25 switch . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-27 while . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-33
Chapter 4 PSL Built-in Functions
Categories of PSL Built-in Functions . . . . . . . . . . . . . . . . . . . . . . . . 4-2 acos() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-8 annotate() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-9 annotate_get() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-14 asctime() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-16 asin() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-19 atan() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-20 atexit() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-22 blackout() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-24 cat() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-29 ceil() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-31 chan_exists() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-32 change_state() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-33 chart() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-35 close() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-39 cond_signal() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-41 cond_wait() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-42 console_type() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-46 convert_base() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-47 convert_date() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-49 cos() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-52 cosh() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-55 create() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-57 date() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-62 debugger() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-63 desktop() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-64 destroy() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-65 destroy_lock() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-66 difference() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-67 dump_hist() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-69 encrypt() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-73 event_archive() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-75 event_catalog_get() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-81
BMC Software, Inc., Confidential and Proprietary Information
Contents
event_check() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-84 event_query() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-88 event_range_manage() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-95 event_range_query() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-97 event_report() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-99 event_schedule() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-104 event_trigger() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-111 event_trigger2() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-113 execute() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-115 exists() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-118 exp() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-120 fabs() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-121 file() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-122 floor() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-124 fmod() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-125 fopen() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-126 fseek() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-130 ftell() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-132 full_discovery() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-134 get() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-135 get_chan_info() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-136 getenv() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-140 getpid() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-142 getpname() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-143 get_ranges() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-144 get_vars() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-148 grep() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-150 history() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-152 history_get_retention() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-155 index() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-156 int() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-157 internal() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-158 intersection() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-159 in_transition() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-160 isnumber() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-162 is_var() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-164 join() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-165 kill() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-166 length() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-167 lines() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-168
BMC Software, Inc., Confidential and Proprietary Information
vi
lock() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-169 log() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-172 loge() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-173 log10() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-175 ntharg() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-177 nthargf() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-180 nthline() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-183 nthlinef() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-185 num_consoles() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-187 pconfig() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-189 popen() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-201 popup_report() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-203 pow() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-206 print() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-208 printf() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-209 proc_exists() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-213 process() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-214 PslExecute() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-217 PslSetOptions() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-219 random() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-220 read() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-222 readln() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-224 refresh_parameters() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-226 remote_close() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-228 remote_event_query() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-229 remote_event_trigger() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-235 remote_file_send() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-237 remote_open() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-242 remove() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-250 replace() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-252 response() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-253 response_get_value() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-311 rindex() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-314 set() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-316 set_alarm_ranges() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-318 share() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-321 sin() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-323 sinh() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-325 sleep() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-327 snmp_agent_config() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-329
BMC Software, Inc., Confidential and Proprietary Information
Contents
vii
snmp_agent_start() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-331 snmp_agent_stop() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-332 snmp_close() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-333 snmp_config() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-335 _snmp_debug() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-339 snmp_get() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-341 snmp_get_next() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-343 snmp_h_get() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-345 snmp_h_get_next() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-348 snmp_h_set() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-351 snmp_open() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-354 snmp_set() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-356 snmp_trap_ignore() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-359 snmp_trap_listen() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-360 snmp_trap_raise_std_trap() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-363 snmp_trap_receive() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-364 snmp_trap_register_im() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-368 snmp_trap_send() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-371 snmp_walk() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-373 sort() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-375 sprintf() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-378 sqrt() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-383 srandom() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-385 subset() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-386 substr() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-388 system() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-389 tail() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-391 tan() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-393 tanh() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-395 time() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-397 tmpnam() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-398 tolower() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-399 toupper() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-400 trace_psl_process() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-401 trim() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-403 union() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-405 unique() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-407 unlock() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-408 unset() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-410 va_arg() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-411
BMC Software, Inc., Confidential and Proprietary Information
viii
%DUMP  List Specific Information . . . . . . . . . . . . . . . . . . . . . . . 5-2 %DUMP CHANNELS  List PSL Global Channels . . . . . . . . . . . 5-3 %DUMP LIBRARIES  List Loaded PSL Libraries . . . . . . . . . . . 5-5 %PSL  Execute a PSL Statement . . . . . . . . . . . . . . . . . . . . . . . . . 5-6 %PSLPS  List Current PSL Processes . . . . . . . . . . . . . . . . . . . . . . 5-7 psl  PSL Compiler Command . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5-8
Chapter 6 Diagnosing PSL Program Errors
PslDebug  Run-Time Error Checking Variable . . . . . . . . . . . . . . . 6-2 errno  Error Return Code Variable . . . . . . . . . . . . . . . . . . . . . . . . . 6-6 exit_status  System Return Code Variable . . . . . . . . . . . . . . . . . . . 6-7 Incompatibilities with the C Programming Language . . . . . . . . . . . . 6-8 Operators && and || . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-8 Prefix and Postfix Operators ++ and -- . . . . . . . . . . . . . . . . . . . . 6-8 Break and Continue Statements . . . . . . . . . . . . . . . . . . . . . . . . . 6-9 Common PSL Coding Errors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-10 Character Strings Interpreted as Numbers . . . . . . . . . . . . . . . . . 6-10 Floating Point Numbers Interpreted as Character Strings . . . . . 6-11 Character Strings Interpreted as Variable Names . . . . . . . . . . . . 6-11 PSL Functions That Do Not Modify Their Arguments . . . . . . . 6-12 Functions That Do Not Write to the System Console Window . 6-13 PSL Compiler Warnings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-14 Built-in Function Run-Time Error Messages . . . . . . . . . . . . . . . . . . 6-17
Appendix A Appendix B errno Return Codes Built-in Agent Namespace Variables
Computer Class Built-in Variables . . . . . . . . . . . . . . . . . . . . . . . . . .B-2 Application Class Built-in Variables . . . . . . . . . . . . . . . . . . . . . . . . .B-4 Application Instance Built-in Variables . . . . . . . . . . . . . . . . . . . . . . .B-4 Parameter Built-in Variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .B-6
Contents
ix
Appendix C
The PSL Profiler Tool . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . C-2 Introduction to the PSL Profiler . . . . . . . . . . . . . . . . . . . . . . . . C-2 How to Install the PSL Profiler . . . . . . . . . . . . . . . . . . . . . . . . . C-4 How to Start the PSL Profiler . . . . . . . . . . . . . . . . . . . . . . . . . . C-5 PSL Profiler PSL Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . C-5 About the PSL Profile Viewer (ppv) Tool . . . . . . . . . . . . . . . . . C-8 About the PSL Profiler API . . . . . . . . . . . . . . . . . . . . . . . . . . . . C-9 The PSL Optimizer Tool . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . C-10 Introduction to the PSL Optimizer . . . . . . . . . . . . . . . . . . . . . . C-10 How to Install the PSL Optimizer . . . . . . . . . . . . . . . . . . . . . . . C-10 How to Deactivate the PSL Optimizer . . . . . . . . . . . . . . . . . . . C-11 About the PSL Optimizer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . C-11 Optimization Levels . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . C-11 Optimization Criteria . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . C-15 Command-Line Specified Options . . . . . . . . . . . . . . . . . . . . . . C-17
Index
Figures
Figures
Figure 1-1 Figure 4-1 Tree Structure of PATROL Applications and Objects . . . . . . . . 1-11 response() Function Example Dialog Box . . . . . . . . . . . . . . . . . 4-308
Figures
xi
xii
Tables
Tables
Table 2-1 Table 2-2 Table 2-3 Table 2-4 Table 2-5 Table 2-6 Table 2-7 Table 2-8 Table 2-9 Table 2-10 Table 2-11 Table 4-1 Table 4-2 Table 4-3 Table 4-4 Table 4-5 Table 4-6 Table 6-1 Table B-1 Table B-2 Table B-3 Table B-4 Examples of PSL Data Types . . . . . . . . . . . . . . . . . . . . . . . . . . 2-2 PSL Predefined Constants . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-4 PSL String Literals. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-6 PSL Arithmetic Operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-10 PSL Assignment Operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-11 PSL Increment/Decrement Operators . . . . . . . . . . . . . . . . . . . . 2-12 PSL Bitwise Operators. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-12 PSL Logical Operators. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-13 PSL Relational Operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-14 PSL Shift Operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-14 PSL Operator Precedence and Associativity . . . . . . . . . . . . . . . 2-17 PSL Built-in Functions (Part 1 of 6) . . . . . . . . . . . . . . . . . . . . . 4-2 event_catalog_get() Function Macro Variables . . . . . . . . . . . . . 4-82 event_query() Function Macro Variables. . . . . . . . . . . . . . . . . . 4-92 PSL errno Variable to pconfig() Message Cross Reference. . . . 4-196 Decimal and Octal File Permissions . . . . . . . . . . . . . . . . . . . . . 4-240 Elements that a Dynamic response() Function Can Update . . . 4-297 PslDebug Error Checking Flag Bits . . . . . . . . . . . . . . . . . . . . . 6-2 Computer Class Built-in Variables . . . . . . . . . . . . . . . . . . . . . . .B-2 Application Class Built-in Variables . . . . . . . . . . . . . . . . . . . . . .B-4 Application Instance Built-in Variables . . . . . . . . . . . . . . . . . . .B-4 Parameter Built-in Variables . . . . . . . . . . . . . . . . . . . . . . . . . . . .B-6
Tables
xiii
xiv
About . . .
xv
Title
"PSL Language Overview" "PSL Data Types and Operators" "PSL Statements"
Purpose
Introduces the PATROL Script Language (PSL), briefly explaining what PSL is and how it works. Identifies the available PSL data types, constants, and operators. Describes the statements inherent in PSL. These statements include:  do...until, if, for, foreach, and while for basic program loops  function for defining user-defined functions  requires and export for importing and exporting PSL libraries into a program Describes the PSL built-in functions that support powerful and efficient PSL programs. Describes commands that you enter from the operating system command line, including commands for the PSL compiler, the one-line PSL function entry, and the PSL process list.
2 3
xvi
Chapter
6
Title
"Diagnosing PSL Program Errors"
Purpose
Provides help in diagnosing PSL errors through debugging aids and error messages. This chapter describes the following:  PslDebug, errno, and exit_status variables  incompatibilities with the C programming language  common coding errors  compiler warnings  built-in function run-time error messages Lists the error codes that are returned by the PSL built-in functions. Describes the variables that are available within PATROL products and can be used in PSL statements. Describes additional PSL tools that can be used when developing PSL scripts.
A B
"errno Return Codes" "Built-in Agent Namespace Variables" "Additional PSL Tools"
Related Documentation
BMC Software products offer several types of documentation:    online and printed books online Help release notes
xvii
You can access online books from the documentation compact disc (CD) that accompanies your product or from the World Wide Web.
Accessing Books with Acrobat Reader
Online books are formatted as Portable Document Format (PDF) files. You can view them, print them, or copy them to your computer by using Acrobat Reader 3.0 or later.
Note
In some cases, installation of Acrobat Reader and downloading the online books is an optional part of the product-installation process. For information about downloading the free reader from the Web, go to the Adobe Systems site at http://www.adobe.com. For information about installing the reader from the documentation CD, see the readme.txt file on the CD.
Accessing Books on the Web
To access any online book that BMC Software offers, visit the support page of the BMC Software Web site at http://www.bmc.com/support.
Note
To use the support page, you must be a registered user or have a temporary user name and a password. If you are a registered user, proceed as follows: 1. Click Log in to Support. 2. Enter your user name and password. 3. To view books for a particular product, click the product name in the Product Directory. 4. Select the book that you want to view.
BMC Software, Inc., Confidential and Proprietary Information
xviii
If you are not a registered user, choose one of the following options:  To register, click Request UserID, complete the form, and click Send
Request.
To request a temporary user name and a password, contact your BMC Software sales representative.
BMC Software provides a core set of printed books with your product order. To request additional books, go to http://www.bmc.com/support.
Release Notes
Printed release notes accompany each BMC Software product. Release notes provide up-to-date information such as   updates to the installation instructions last-minute product information
The latest versions of the release notes are also available on the Web at http://www.bmc.com/support.
xix
Formatting Conventions
The following formatting elements have been added to make this reference easier to use:
Note
A note contains text that is thematically related to the surrounding body text but is of special or unusual significance.
Tip
A tip informs you of an action that, while not prohibited within PSL and not a recognizable problem, may lead to unexpected results or errors within PSL, PATROL, and/or the host operating system.
Warning
A warning identifies an action that may result in damage to, or loss of, software and/or data. The PSL statement and built-in function descriptions use ellipses ( . . . ) to indicate parameters that may be indefinitely replicated within the statement or function. For example, the function format
snmp_get(session,variable1,variable2, . . . ,variablen)
indicates that variable can be specified an arbitrary number of times within the snmp_get() function, whereas the statement format:
xx
switch (variable) { case a: {BLOCK} case b: {BLOCK} . . . case p,q,r: {BLOCK} . . . case n: {BLOCK} default: {BLOCK} }
indicates that the construction case n: {BLOCK} can be repeated within the statement an arbitrary number of times.
Statement and Built-in Function Descriptions
The PSL statement and built-in function descriptions in Chapters 3 and 4 use formatting conventions widely used in computer programming language reference manuals. That format consists of the following: statement or function title and an optional single-sentence description a detailed format and parameter description a detailed description of statement or function action, restrictions, dependencies, and error conditions
The warning and error messages described in Chapter 6 use formats similar to other BMC Software publications. The order of the warning and error description is as follows: error message text title description of the problem communicated in the message reason the problem might have occurred possible solutions to the problem
xxi
Font Conventions
This reference uses several fonts to emphasize and/or distinguish elements in the general text and within statement and built-in function descriptions. Following is a summary of these fonts:
Convention
Courier
Description
This font has the following uses:  It is used in statement and built-in function formats to indicate characters and symbols that must be typed as shown when entering the command. For example, the command format proc_exists(pid) indicates that proc_exists() must be typed exactly as shown when entering the command, whereas pid is a variable that should be replaced with a numeric or character string as directed by the parameter description.  It is used within statement and built-in function descriptions to identify a PSL statement or built-in function label. For example, in the sentence
The close() function closes a channel opened using the fopen() or popen() functions.
the font is used to distinguish close(), fopen(), and popen() as PSL built-in functions.  It is used to identify UNIX operating system and C programming language commands and syntax. For example, the statement
xxii
Convention
Times italic
Description
This font has three uses:  It is used in the left margin of a page to indicate the Problem, Cause, and Solution portions of a warning or error message description.  It is used in the body text to emphasize a word or phrase. For example, the phrase
the popen() function only opens channels to processes emphasizes the word only as significant.
 It is used in statement and built-in function formats and descriptions to indicate a required variable or option within the statement or built-in function. For example, the function format proc_exists(pid) indicates that pid is a variable that should be replaced with a numeric or character string as directed by the parameter description, and the phrase:
the proc_exists() function determines if the PSL process with process identifier pid exists indicates that pid is a variable of the proc_exists() function.
Times italic underlined This font is only used in statement and built-in function formats to indicate variables which are optional and may be omitted from the command. For example, the command format popen(command,type,instance) indicates that the variables command and type must be specified for the popen() function, but instance is optional and can be omitted.
xxiii
Mouse Controls
The following table shows equivalent mouse buttons for Unix users and Windows NT users:
Unix Button
MB1
Windows NT Button
left mouse button
Description
Click this button on an icon or menu command to select that icon or command. Click MB1 on a command button to initiate action. Double-click an icon to open its container. Click this button on an icon to display the InfoBox for the icon. To simulate MB2 on a two-button mouse, simultaneously press the two buttons (MB1 and MB3). Click this button on an icon to display its pop-up menu.
MB2
not applicable
MB3
Note
If you have a one-button mouse (such as an Apple Macintosh mouse), assign MB1 to that button. You should also define a user-selectable combination of option and arrow keys to simulate MB2 and MB3. For details, refer to the documentation for your emulation software.
xxiv
1
1 1
This chapter provides an overview of PATROL Script Language (PSL) and includes information about the following: What Is PSL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-2 Interpreted PSL Scripts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-2 Compiled PSL Binary Files . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-2 Optimization . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-3 Diagnostics. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-3 PSL Built-in Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-3 Locking Functions for Concurrency Control. . . . . . . . . . . . . . . . 1-4 Set Functions for PSL Lists . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-4 PSL Mathematical Functions. . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-5 PSL Libraries . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-6 PSL Process Synchronization. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-7 PSL Shared Global Channels . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-7 The Need for Shared Global Channels in PSL . . . . . . . . . . . . . . 1-7 The Implementation of PSL Shared Global Channels. . . . . . . . . 1-8 The Effect of PSL Shared Global Channel Mechanisms. . . . . . . 1-9 How to Use PSL in PATROL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-9 Complex Application Discovery . . . . . . . . . . . . . . . . . . . . . . . . . 1-9 Advanced User Commands . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-10 Efficient Monitoring Parameters . . . . . . . . . . . . . . . . . . . . . . . . . 1-10 How PSL Relates to PATROL Architecture. . . . . . . . . . . . . . . . . . . . 1-11 Using Built-in or User-Defined Object Variables . . . . . . . . . . . . . . . 1-13 PSL Naming Conventions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-14
1-1
What Is PSL
PSL is both an interpreted and a compiled language for writing complex application discovery procedures, parameters, and commands within the PATROL environment. It is also a good language for writing arbitrary commands and tasks. PSL has been designed to provide functions needed to efficiently develop Knowledge Modules for the PATROL environment. To accomplish this, PSL sacrifices some of the completeness of languages such as C, csh, Perl, or awk while implementing some of the statements and functions that make those languages so powerful and popular. Users familiar with one of those languages should have little difficulty adapting to PSL.
1-2
Optimization
Like C, PSL does a certain amount of expression evaluation at compile time, whenever it determines that all of the arguments to an operator are static and have no side effects. In particular, string concatenation is done at compile time between string literals. Backslash interpretation is also done at compile time. You can say
Now is the time for all .\n . good men to come to.
and this expression is reduced to one string internally. PSL is also highly efficient. The language is not immediately interpreted, but instead is compiled into an internal form, which is then executed by a high-speed interpreter.
Diagnostics
If any compilation errors are encountered when a PSL script is compiled, error messages tell you the line number of the error and briefly describe the cause of the error. See Chapter 6, Diagnosing PSL Program Errors, for further information.
1-3
list
These functions process PSL lists as sets of elements. Each member of a list is text string that ends with a new-line character. (The text string cannot contain embedded new-line characters.) Although the set functions will properly handle lists whose last element does not end with a new-line character, BMC Software recommends that you ensure that all elements, including the last element, are followed by a new-line character. The NULL set [""] is the equivalent of the null or empty set () in set theory. The NULL set is treated by the PSL set functions as a proper set that contains no elements.
BMC Software, Inc., Confidential and Proprietary Information
1-4
The NULL string [] is a PSL list element with no characters. The PSL set functions allow lists to contain NULL strings, but BMC Software discourages their use because their unique characteristics can produce unexpected results. The PSL concept of a set is not the unique list of ascending or descending elements familiar to set theory. In many cases, the PSL lists contain duplicate elements arranged in no particular order. A PSL list can be transformed into an ordered set using the unique() function to remove duplicates and the sort() function to arrange the elements in ascending or descending order.
Although most issues involving the C mathematical functions are standardized, there are platform-specific differences such as levels of accuracy; and the different handling of various out-of-range conditions may cause them to behave differently on different platforms. All PSL functions except one have the same name as the corresponding C function. The exception is that the loge() function corresponds to Cs log() function since PSL already has a log() function used for logging events. The log() function has been augmented with a run-time error it returns when it receives a numeric value. This error message will reduce the likelihood of accidentally calling it when the loge() function was intended.
Note
Although the log() function is now functionally replaced by the event_trigger() function, the log() function is still supported for backward compatibility.
BMC Software, Inc., Confidential and Proprietary Information
1-5
The PSL mathematical functions include some run-time error checking for range and domain. Both conditions result in a run-time error message that sets the PSL errno variable to an appropriate value. Additionally, any nonnumeric values produced by printing the result of the function call, such as Nan or -Inf are converted to 0.0 to prevent the return value from being interpreted by PSL as a nonnumeric character string. The PSL function also returns a run-time error message when it performs the conversion. Note that some PSL domain errors may not exactly match those of the standard C library: The PSL functions and argument ranges raise a domain error and return zero. The C functions may raise a range error and/or return a non-numeric representation of the result such as infinity in the following cases: loge(x) and log10(x) when x 0 sqrt(x) when x < 0 fmod(x,0)
PSL Libraries
PSL supports shared libraries of PSL user-defined functions. PSL libraries are binary files that can be loaded into another PSL program using the PSL requires statement. The PSL libraries can be loaded in either of the following ways:  staticallymixing the library object code and symbol table into the PSL program to create a larger binary dynamicallyrequesting at PSL program startup that the PatrolAgent find the required library in its repository of libraries (that is, probably in the Knowledge Module or in the directory specified by the PATROL_HOME or HOME environment variable)
BMC Software, Inc., Confidential and Proprietary Information
1-6
If the PatrolAgent cannot find the library, program execution fails. If the PatrolAgent finds the library, it dynamically loads it as a shared library. Shared libraries are loaded only once by the PatrolAgent; and all PSL processes using that library (with dynamic loading) will share the library object code and constants but will have their own copy of library variables.
1-7
no way to have distinct poll times for the various consumers no convenient way to deactivate queries that were deemed unnecessary
All the agent scheduling features were lost unless the Knowledge Module developer could explicitly code the equivalent functionality into the collectors PSL code.
1-8
1-9
Typical PSL discovery scripts include RDBMS discovery, file system discovery, and so on.
1-10
The object and variable naming conventions used by the PatrolAgent are similar to those of the UNIX file system. They are not file names however, and you should not be concerned if they do not conform to the file naming conventions for your particular operating system. Figure 1-1 shows how application objects can have variables and instances. In turn, the application instances can have variables and parameters, which in turn can have variables.
Figure 1-1
1-11
As shown in Figure 1-1, the root of the hierarchy is the computer. The computer (root) directory contains the applications. Each application directory contains all the application instances. Each instance directory contains all the parameters for each instance and so on. The designation /RDB/Dev refers to the RDB database named Dev. Variables (such as name) are analogous to files within a directory. The status of this database instance would be referenced as /RDB/Dev/status.
Note
Conceivably, status could be the name of a parameter on Dev, in which case a conflict would exist. It is recommended that you begin all variable names with a lowercase letter and all object names (parameters, applications, etc.) with an uppercase letter to avoid name conflicts. Refer to PSL Naming Conventions on page 1-14 for more information on developing Knowledge Modules which conform to PSL style guidelines. The designation /RDB/Dev/Status is an object (a parameter) because it begins with a capital letter and /RDB/Dev/status is a variable for the Dev instance of the RDB application. The value of the parameter Logons on database Dev would be referenced as /RDB/Dev/Logons/value. Once you define an object you do not normally have to give the absolute name each time you reference it. You can make use of the context in which the script you are developing will run to construct shorter, relative names for most objects. The context of a script is the name of the object to which the executing script belongs. For example, if you write a script for the discovery of the RDB application, its context will be the application class it is discovering.
1-12
Whenever you give the name of an object without a preceding /, PatrolAgent prefixes the name with the current context. Using the previous example, if we gave the object name Dev, it would be expanded to /RDB/Dev automatically. The reference .. is reserved to mean the parent of the current context. For example, the reference ../name in an application discovery script refers to the name of the computer since the computer is the parent object of all application class objects. In a parameter, it refers to the application instance name since the parent of a parameter is its application instance.
A full list of built-in variables available on each PATROL object is listed in Appendix B, Built-in Agent Namespace Variables.
1-13
Convention
All uppercase letters Initial capitalization Use a few letters of the parameters application class. Initial cap each word in the name. Begin with a lowercase letter. Initial cap each word in the name after the first word.
Example
/FILESYSTEM /MYAPP /MYAPP/Instance1 /FILESYSTEM/etc/FSInodesPctUsed /MYAPP/Instance1/MYFirstParam /MYAPP/Instance1/numUsers
Variable
Generally,
the instances name is dictated by the name of the real-life object that it represents, so following this convention is not always possible, as in /FILESYSTEM/etc.
1-14
2
2 2
This chapter provides information on the syntax of PSL. Examples are included to help you understand how to write PSL scripts. PSL Data Types and Objects . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-2 Numeric Constants. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-2 PSL Variables. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-3 Default Initialization of PSL Variables . . . . . . . . . . . . . . . . . . . . 2-3 PSL Predefined Constants . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-4 PSL String Literals. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-6 PSL Here Documents. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-7 ActiveX Scripts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-8 PSL Lists . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-8 PSL Simple Statements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-9 PSL Operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-10 Arithmetic Operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-10 Assignment Operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-11 Increment/Decrement Operators . . . . . . . . . . . . . . . . . . . . . . . . . 2-12 Bitwise Operators. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-12 Logical Operators. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-13 Relational Operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-14 Shift Operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-14 String Operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-15 Ternary Operator . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-16 PSL Operator Precedence and Associativity . . . . . . . . . . . . . . . . 2-17
2-1
Data Type
integer float string list 3 4.5
Example
Representation
"3" "4.5" "abc" "1\n3\n5"
abc [1,3,5]
Variables and values are interpreted as either strings or numbers, whichever is appropriate to the context. A scalar (integer or float) is interpreted as true in the Boolean sense if it is not the null string or 0. Booleans returned by operators are 1 for true and 0 or (the null string) for false.
Numeric Constants
Although the internal representation of an integer or floating-point constant is a string, these constants need not appear inside quotation marks in PSL scripts. Integer and floating-point constants can be used in the same way as in the C programming language. For example,
x = 3; pi = 3.14159;
2-2
PSL Variables
Variables of any type can be used as valuesthat is, they can be assigned to. As all data types are treated as strings internally, they all share a common name space. Therefore, you cannot use the same name for a scalar variable, a string variable, and a list variable. Case is significant. FOO, Foo, and foo are all different names. Names must start with a letter or an underscore but can contain digits and underscores (_). Some identifiers have predefined meanings. Reserved keywordssuch as if and foreachcannot be used as identifiers. Keywords are recognized as either all lowercase or all uppercase letters. In addition, the predefined constants listed in Table 2-2, PSL Predefined Constants, on page 2-4 cannot be used as identifiers.
For more information on enabling runtime warnings, see PslDebug Run-Time Error Checking Variable on page 6-2.
2-3
Constant
not currently implemented not currently implemented destroys a previously loaded chart loads a chart prints a previously loaded chart
2-4
Table 2-2
Constant
R_LIST_MULTIPLE_ND R_LIST_SINGLE R_LIST_SINGLE_ND R_MENU R_POPUP R_POPUP_SCROLLED R_RADIO_HORIZ R_RADIO_VERT R_ROW R_SCALE_HORIZ R_SCALE_VERT R_SEP_HORIZ R_SEP_VERT R_SPINNER R_TEXT_FIELD R_TEXT_FIELD_LABEL R_TOGGLE
Definition
multiple-select scrolled list without defaults single-select scrolled list with defaults single-select scrolled list without defaults option menu nonscrolled popup scrolled popup horizontal radio button vertical radio button row compound element horizontal sliding scale vertical sliding scale horizontal separator vertical separator time spinner button text entry box without a label text entry box with a label toggle button
Other Constants
EOF true/TRUE/True yes/YES/Yes false/FALSE/False no/NO/No End-of-file condition constant Boolean true value (logical 1) Boolean false value (logical 0)
2-5
Constant
\t \n \r \b \A . . . \Z
Definition
tab new-line return backspace Ctrl-A . . . Ctrl-Z
Control characters can be embedded in PSL string constants using \A through to \Z to represent Ctrl-A through to Ctrl-Z. A capitalized letter must always be used; lowercase letters other than those already defined (that is, t, n, r, or b) are not valid as escapes and will generate a PSL compilation warning. When using a \ (backslash) in a string literal, two \\ (backslashes) must be used because the first will be interpreted as a control character, and the second will be used as part of the string. A path for a Windows NT host should be represented in a string as follows:
C:\\PATROL\\lib\\PSL\\
2-6
Everything between the two delimiters, Here_Doc_DELIMIT, represents the here_document variable text string.
2-7
ActiveX Scripts
With the PATROL Agent for Windows NT 4.0, the execute() function can submit an ActiveX script to the PATROL Scripting Host. The ActiveX script can be vbscript, javascript, or any valid Microsoft ActiveX scripting language. When the execute() function submits an ActiveX script to the PATROL Scripting Host, the PSL process is suspended, and the script is sent to the PATROL Scripting Host. When the script finishes, the PSL process returns to the PSL run queue for execution.
Note
The script option is only available with the PATROL Agent for Windows NT 4.0. For more information on submitting ActiveX scripts with the execute() function, see execute() on page 4-115.
PSL Lists
List values are denoted by separating individual values with commas and by enclosing the list in square brackets: [1, 3, 5] The list is interpolated into a double-quoted string whose elements are separated by new-line characters. The list is represented internally as
"1\n3\n5"
2-8
PSL expression statements work similar to C expressions. The only difference is the addition of several string operators. See String Operators on page 2-15.
2-9
PSL Operators
Arithmetic Operators
For arithmetic operators, an operand is considered a number if its first character is a digit or a minus sign (). Otherwise, it is considered a string and converted to 0 for an empty string or 1 for a nonempty string. The use of a nonnumber in an arithmetic context may result in a runtime warning, as discussed in PslDebug  Run-Time Error Checking Variable on page 6-2.
Table 2-4 PSL Arithmetic Operators
Operator
+ / * %
Definition
addition subtraction division multiplication modulus
2-10
Assignment Operators
Following are the assignment operators for PSL.
Table 2-5 PSL Assignment Operators
Operator
= += -= /= *= %=
Definition
assignment self-addition self-subtraction self-division self-multiplication self-modulus
Bitwise Assignment:
&= |= ^= self-bitwise AND self-bitwise OR exclusive OR bitwise assignment
Shift Assignment:
<<= >>= shift left assignment shift right assignment
2-11
Increment/Decrement Operators
For information about limitations with increment/decrement operators, see Incompatibilities with the C Programming Language on page 6-8.
Table 2-6 PSL Increment/Decrement Operators
Operator
++ --
Definition
increment decrement
Bitwise Operators
Following are the bitwise operators defined for PSL.
Table 2-7 PSL Bitwise Operators
Operator
& | &= |= ^ ^=
Definition
bitwise AND bitwise OR self-bitwise AND self-bitwise OR exclusive OR bitwise exclusive OR bitwise assignment
2-12
Logical Operators
The PSL logical operators assume for their operands that true is represented by 1 or a nonempty string. False is represented by 0 or an empty string. However, when they return results, they always use 1 for true and 0 for false. For further information about limitations with logical operators, see Incompatibilities with the C Programming Language on page 6-8.
Table 2-8 PSL Logical Operators
Operator
&& || !
Definition
logical AND logical OR logical negation (NOT)
2-13
Relational Operators
The relational operators perform numeric comparisons if both operands are numbers. Otherwise they perform string comparisons (that is, lexical, dictionary ordering). A string is considered a number if it consists of only digits, the minus sign, or a period. No white space is allowed. PSL relational operators do not consider constants in C-like exponential notation (such as 2.3e+27) to be numbers.
Table 2-9 PSL Relational Operators
Description
equal to not equal to less than greater than less than or equal to greater than or equal to
Shift Operators
The shift operators perform bit shifting within bytes.
Table 2-10 PSL Shift Operators
Description
shift left shift left assignment shift right shift right assignment
2-14
String Operators
PSL has special operators for string and list manipulation that are not found in C.
. (period)
The period indicates the concatenation of two strings. For example, "ab"."cd" is equal to "abcd".
[s1, s2, ...]
The list operator builds a list by joining all elements in a comma-separated list into a double-quoted string of items delimited by a new-line characters, which is PSLs representation for lists/arrays.
=~ (equal tilde)
The =~ operator is used in the expression string =~ pattern and returns 1 if the regular expression pattern is contained in string 0 if the regular expression pattern is not contained in string
If pattern is invalid, PSL returns a runtime error message and the =~ operation returns 0 (pattern not contained).
!~ (tilde)
The !~ operator is used in the expression string !~ pattern and returns 1 if the regular expression pattern is not contained in string 0 if the regular expression pattern is contained in string
If pattern is invalid, PSL returns a runtime error message and the !~ operation returns 0 (pattern contained).
2-15
Ternary Operator
The PSL ternary operator ?: behaves similarly to the C conditional expression in that it connects three operands and offers an alternative way of expressing a simple if...else statement. The format for the PSL conditional expression is as follows:
result = expression1 ? expression2 : expression3;
If expression1 is TRUE (nonzero), then expression2 is evaluated; otherwise, expression3 is evaluated. The value for the complete conditional expression is the value of either expression2 or expression3, depending on which expression was evaluated. The value of the expression may be assigned to a variable. Conditional expressions are most useful in replacing short, simple if...else statements. For example, the if...else statement
if (x==1) { y=10; } else { y=20; }
These examples perform the same function. If x is 1, then y becomes 10 else y becomes 20.
2-16
Operator
= +=, -=, <<=, >>=, ^= *=, /=, %= |=, &= ?: (ternary) || && | ^ & !=, ==, =~, !~ <, <=, >, >= <<, >> +, - (binary) *, /, % . (string concat) -, !, ++, -() []
Precedence
lowest
Associativity
right right right right right left left left left left left left left left left left right left
highest
left
2-17
2-18
3
3 3
PSL Statements
This chapter describes the statements that are supported by PSL.
Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-2 PSL Compound Statements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-2 do...until . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-4 exit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-6 export . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-7 for . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-9 foreach . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-11 function. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-13 The return Statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-14 Functions with Variable Length Argument Lists . . . . . . . . . . . . . 3-15 Defining Local Variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-16 Entry Point Function . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-17 Start of Execution Without an Entry Point Function . . . . . . . . . . 3-18 Backward Compatibility with Earlier PSL Versions . . . . . . . . . . 3-19 Limitations of User-Defined Functions . . . . . . . . . . . . . . . . . . . . 3-19 if . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-21 last. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-23 next . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-24 requires . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-25 switch . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-27 while . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-33
PSL Statements
3-1
Introduction
A PSL script consists of a sequence of commands. All uninitialized user-created objects are assumed to start with a NULL or 0 value until they are defined by some explicit operation such as assignment. PSL is, for the most part, a free-form language. That is, lines dont have to start or end at or before a particular column; they can just continue on the next line. White space is ignored except for the separation of tokens. Comments are indicated by the # character and extend to the end of the line. For example, here is a comment about an assignment statement:
x = y; # Assign the value of y to the variable x
3-2
switch(variable) { case m: {BLOCK} ... case n: {BLOCK} default: {BLOCK} } while (expression) {BLOCK}
These compound statements are defined in terms of statement blocks, not statements. This means that the braces are required rather than optional. No dangling statements are allowed.
PSL Statements
3-3
do...until
Format
do { {BLOCK} } until (expression);
Parameters
Parameter BLOCK expression Definition
One or more PSL statements that are repeatedly executed until the evaluation of expression is TRUE A PSL statement whose evaluation returns either TRUE or FALSE. If TRUE, the loop terminates.
Description
The PSL do...until loop behaves similarly to the C do...while loop construct in that it tests the termination condition at the end of the loop after making each pass through the body of the loop. Therefore, the body is always executed at least once. At first pass, the BLOCK of statements is executed, then expression is evaluated. If expression is FALSE, the BLOCK of statements is executed again. Iteration repeats until expression is TRUE.
3-4
Example
The following example demonstrates the PSL do...until loop:
i = 10; do { printf(" %d seconds to go\n",i); i--; sleep(i); } until ( i == 0);
PSL Statements
3-5
exit
Format
exit;
Description
The exit statement causes the PSL program to immediately end and return control to the process that called it. The exit statement must be terminated with a semicolon when used in a PSL program.
3-6
export
Format
export variable; export function function;
Parameters
Parameter variable function Definition
Name of a PSL variable that is available for export to another PSL program Name of a PSL function that is available for export to another PSL program
Description
The export statement makes a variable or function in a PSL library available for export to another PSL library or program using the requires statement. Each export statement can specify a single variable or function. Global variables and functions need not be declared before the export statement. The export statement does not require that a variable be explicitly defined within a library, but it does require that it appear in a PSL statement to create an implicit definition.
Placement of the export Statement
The export function function statement can appear before or after the actual function definition. The export variable statement can appear before or after the first appearance of a global variable.
PSL Statements
3-7
An export statement can appear inside a function definition without any special significance. BMC Software discourages placing export statements inside function definitions.
Errors involving the export Statement
The export statement can generate compiler errors in the following instances:     
variable or function is not defined or used in the library variable or function is a PSL built-in function variable is a local variable of a user-defined function in the library variable or function is duplicated in another export statement variable or function has been imported using the requires statement
3-8
for
Format
for (initexpr; termexpr; reinitexpr) { {BLOCK} }
Parameters
Parameter initexpr termexpr reinitexpr BLOCK Definition
A PSL statement whose evaluation initializes the loop A PSL relational expression whose evaluation determines the continuation or termination of the loop A PSL statement whose evaluation reinitializes the loop One or more PSL statements that are executed once in accordance with the evaluation of the expressions
Description
The for loop behaves similarly to the C for loop construct in that it is an iteration statement in which the following occurs: 1. The first expression initexpr is evaluated once, initializing the loop. 2. The second expression termexpr is evaluated before each iteration and, if it becomes equal to 0, the for loop terminates. 3. The third expression reinitexpr is evaluated after each iteration, reinitializing the loop. The for loop is equivalent to
initexpr;
while (termexpr) {
BMC Software, Inc., Confidential and Proprietary Information
PSL Statements
3-9
BLOCK reinitexpr;
}
Generally, initexpr and reinitexpr are assignments or function calls, and termexpr is a relational expression. Any of the three expressions may be omitted; however, the semicolons must remain. A missing second expression termexpr makes the implied test equivalent to testing a non-zero constant (or a permanently true expression).
Example
The following example demonstrates the for loop:
for (i = 10; i > 0; i--) { printf(" %d seconds to go\n",i); sleep(1); }
3-10
foreach
Format
foreach variable (list) {BLOCK} foreach unit variable (list) {BLOCK}
Parameters
Parameter list BLOCK unit Definition
A list that contains one or more elements that can be equated to variable One or more statements that are executed when variable has been equated to an element from list Controls how list is split into individual elements. Valid Range:  word assumes that the array elements are separated by white space (spaces, tabs, or \n)  line assumes that array elements are separated by \n Default if not specified: line The name of the element that is equated to each element in list
variable
Description
The foreach loop iterates over list and sets variable to be each element of list, performing BLOCK for each element of list in turn.
PSL Statements
3-11
Examples
The following examples highlight the usage of the foreach statement.
Sum the Elements in an Array sum = 0; foreach elem ("1\n2\n3\n4\n5") { sum += elem; } List the Login ID of Each Account on the System foreach user (cat("/etc/passwd")) { print (ntharg(item, 1, ":"), "\n"); } Note
cat()
Count the Number of Words in a String words = 0; foreach word w ("The cat sat on the mat.") { words++; }
3-12
function
Format
function name(argument-list,...) {BLOCK}
Parameters
Parameter name Definition
Character label that is used to identify and call the function from within the PSL program; name cannot be identical to either of the following:  a PSL built-in function  a PSL variable Zero or more PSL variables that are passed to the function as parameters when it is called for execution. argument-list can be a NULL entry if no variables are passed to the function, a single argument, or several arguments separated by commas. Optional ellipses indicating that the function will accept an additional variable number of arguments. This variable portion of the argument list is processed using the va_start() and va_arg() PSL built-in functions. See Functions with Variable Length Argument Lists on page 3-15, va_arg() on page 4-411, and va_start() on page 4-413 for more information. One or more PSL statements that define the action the function performs
argument-list
...
BLOCK
Description
The function statement provides user-defined functions within PSL programs similar to those available in the C programming language. The function keyword is required in a user function definition. Two additional keywords, local and return, are optional:
PSL Statements
3-13
local declares variables that will be used only within the function. return identifies function output that is returned to the caller
Functions must be defined before their first use, and the correct argument-list must be passed in a function call. A function call always returns a character string representing a character string or numeric value. (All data types are represented within PSL as character strings.) Arguments are passed-by-value to parameters (that is, local copies are created of the arguments data passed in), and thus changing a parameter will not affect the value of the argument. Function parameters are local to a function and can have names the same as global variables (or the same as parameters of other functions). If a function definition appears in the middle of executable statements and control flow reaches that definition from above, the definition is skipped as if it were a comment. The only way to enter the body of a function is to explicitly call it. The function definitions serve merely to define a function and are not invoked until called. Hence, it is possible to place executable code above, below, and between function definitions.
PSL does not interpret falling through the bottom of a function as an error condition, although BMC Software does not recommend relying on fall-through for a function whose return value is used.
3-14
PSL produces a compilation warning similar to that produced by C compilers when it encounters return statements within a function some of which have return values and while others do not. Having multiple exit points in a function that exit in different ways may indicate confusion over whether the function was defined to be perform an action or return a value. BMC Software recommends that you design functions that return a value to explicitly return the NULL string when they have no other value to return. This is preferred to exiting the function with a return statement and no return value.
Because argno1 and argno2 are fixed arguments, they must be included in every call to my_func(). The ellipses, however, indicate that any number of additional arguments may also be included in a call to my_func(). For example, the following are legal calls to my_func() because each includes two or more arguments:
my_func(1,2); my_func(1,2,3,4,5);
The following, however, is not a valid call to my_func() because it does not include the minimum two fixed arguments:
my_func(1); # illegal function call!
PSL Statements
3-15
You can process a variable argument list within your function() statement using the PSL va_start() and va_arg() functions: the va_start() function initializes the variable argument list to return the first argument. You can use the va_start() function multiple times within a function() statement to initialize the variable argument list, allowing the function() statement to traverse the variable argument list more than one time. the va_arg() function returns the current argument in the variable argument list and increments. Successive va_arg() function calls return successive arguments from the variable argument list until all arguments have been returned. Unless you call the va_start() function to reinitialize the variable argument list, the va_arg() function returns a NULL after all variable arguments have been returned.
See va_arg() on page 4-411 and va_start() on page 4-413 for descriptions and examples of the va_arg() and va_start() built-in functions.
3-16
Local variables cannot have the same name as a function parameter or another local variable in the same function. Local variable names in one function do not affect those in another function. Local variables can have the same name as a global variable and can hide a global name this way. BMC Software does not recommend that you use local variables this way, and PSL will generate a compiler warning each time it detects this situation. Local variable declarations are treated as expressions and can appear anywhere within the function that an expression is valid. However, there is no concept of inner scopes in inner blocks and a local variable has scope extending from its point of declaration to the end of the enclosing function (not the enclosing block). BMC Software recommends that you declare all local variables at the start of the function body. Local variables are initialized to the empty string every time the function is entered. They do not retain their values from a previous call. Each user-defined function (except for the main() function) permits a maximum of 20 local variables.
PSL Statements
3-17
You can specify that a user-defined function with a label other than main() be treated as the main program entry point by specifying the -e option to the PSL stand-alone compiler. Refer to Chapter 5, PSL External Commands, for a description of the PSL compiler command and options. The function you specify as the entry point is permitted to have the same properties as main(). The main() function or the entry point function must be defined in the top-level PSL program and not in any imported libraries. Functions imported from libraries are ignored when determining whether an entry point function is available.
3-18
User-defined functions can make unlimited calls to other functions provided that there is no direct or indirect recursion in the sequence of calls. PSL user-defined functions do not support recursion because each function has only one block of memory for its parameters and local variables. A recursive call would overwrite the parameters for the previous (and still active) call. PSL prevents direct recursion by generating a compilation error. The PSL compiler may compile and execute a program with indirect recursion, but the potential for overwriting the parameters and variables for an active function will produce unexpected results.
PSL Statements
3-19
PSL functions do not support argument passing by reference; only argument pass-by value is supported. PSL also has no concept of pointers which are used to mimic pass-by reference in the C programming language.
Parameter and Local Variable Limits
PSL functions have the following parameter and local variable limits: maximum of 10 parameters maximum of 20 local variables
PSL does not permit function nestingeach function definition must be at global scope and cannot be defined inside any other function.
3-20
if
Format
if (expression) {BLOCK} if (expression) {BLOCK} else {BLOCK} if (expression) {BLOCK} elsif (expression) {BLOCK} ... else {BLOCK}
Parameters
Parameter expression BLOCK Definition
A PSL statement whose evaluation returns either TRUE or FALSE One or more PSL statements that are executed once in accordance with the evaluation of the if or elsif expressions
Description
The if statement is straightforward. Because a statement BLOCK is always bounded by braces, there is no ambiguity about which if, elsif, and else goes with.
PSL Statements
3-21
Examples
The following examples highlight the usage of if, elsif, and else.
An if statement
if (x > 10) { x = 10; # dont let x get bigger than 10 }
An if . . . else Statement
if (x == 0) { # do something } else { # x != 0 # do something else }
3-22
last
Format
last;
Description
The last statement causes PSL execution to exit the innermost execution loop. The last statement is equivalent to the C break statement. The last statement must be terminated with a semicolon when used in a PSL program.
PSL Statements
3-23
next
Format
next;
Description
The next statement immediately starts the next iteration of the innermost execution loop. The next statement is equivalent to the C continue statement.
3-24
requires
Format
requires library;
Parameter
Parameter library Definition
Name of the library whose specified export variables and functions are to be imported into the PSL program
Description
The requires statement imports variables and functions identified in export statements from a previously created PSL library into the PSL program. Each requires statement can specify a single library name. PSL contains no explicit import statement; using the requires statement implies importation. The requires statement searches for the binary containing the library and reads all its export statement information, importing the specified variables and/or functions into the PSL program. Any number of requires statements can appear in a PSL program. All libraries specified in requires statements must be available to the compiler during compilation.
requires Statements in Imported Libraries
The PSL compiler will automatically resolve nested dependencies in imported libraries, but it will not automatically load all the other exported functions and variables found in the library that satisfies the nested dependency. You must explicitly import a library in order to guarantee access to all the exported variables and functions within it.
PSL Statements
3-25
A requires statement can appear inside a function definition without special significance. BMC Software discourages placing export statements inside function definitions and recommends that you place all requires statements at the top of the file. BMC Software recommends that you minimize the use of export statements in libraries where the exported variables and functions depend on variables and functions imported with requires statements from other libraries. Following this practice can avoid chains of import dependencies and the possibility of libraries that form requires statement loops.
When a PSL program imports variables and functions from more than one library, the imported variables and functions from one library can set and use the imported variables and functions from the others, regardless of how the libraries are loaded for compilation. BMC Software strongly recommends that you avoid the practice of creating and importing mutually referential libraries. Mutually referential libraries are those that contain a requires statement naming the other library.
Errors Involving the requires Statement
The requires statement can generate compiler errors in the following instances: a reference to an imported variable or function appears before the requires statement that imports it. You must place a requires statement before the first use of the imported variable or function an imported function has the same name as a function defined within the PSL program the same variable or function name is imported from two or more libraries
3-26
switch
Format
switch (expression) { case a: {BLOCK} case b: {BLOCK} ... case p,q,r: {BLOCK} ... case n: {BLOCK} default: {BLOCK} }
Parameters
Parameter expression a,b, . . . p,q,r, . . . n BLOCK Definition
PSL expression whose integer value specifies the PSL statement BLOCK that will be executed Integer values indicating the value of variable that will cause the corresponding BLOCK to be executed One or more statements that are executed when the corresponding case value equals variable
PSL Statements
3-27
Description
The switch statement evaluates expression and based on its integer value executes a specific PSL BLOCK. The case labels correspond to the values of expression for which a specific PSL BLOCK is available. If the value of expression falls outside the range of the values in the case labels, execution continues with the BLOCK corresponding to the default label. If no default label exists, execution will continue with the first statement following the switch statement. The switch statement is similar in form and function to the C switch statement. The PSL switch statement executes in almost the same way as a long sequence of if-then-else-if statements. A case or default clause is effectively a run-time statement that specifies a comparison against the value of expression:  If the value of expression matches a case, execution moves inside the BLOCK for the case or default clause; and after completing BLOCK, execution continues after the entire switch statement (that is, there is no falling through to the next case clause). If the value of expression does not match a case, execution skips to the default clause; and if there is none, execution moves to the statement following the switch statement.
Any statement within the switch statement case block that is not part of a case or default BLOCK executes only if all the case labels above it failed to match expression (that is, it executes as part of the normal sequence of control flow).
3-28
The following differences exist between the PSL switch statement and the C switch statement: PSL case expressions can be dynamically evaluated expressions whereas C only permits constant expressions. The colon delimiter that separates the case label from the executable BLOCK is optional in PSL and required in C. PSL requires that the default label follow all case labels in the switch statement case block, whereas C allows default to appear anywhere within the case labels. PSL returns a compilation error if one or more case labels follow default. PSL does not return a compilation error for duplicate case labels in the switch statement case block whereas C does. In PSL, the second of the duplicate case labels is unreachable. PSL allows multiple cases that execute a common BLOCK to be specified as a comma separated list within a single case label where C requires that each case be a separate case label stacked above a single BLOCK. (Conversely, the stacked labels will not work in PSL.) Execution of a PSL BLOCK does not fall through to the next case label and BLOCK as it does the C switch statement. Upon reaching the closing right brace of a case or default BLOCK, execution moves to the end of the PSL switch statement. The PSL switch statement uses the last statement to exit from a BLOCK whereas C uses the break statement. The last statement exits the innermost switch statement or loop. However, because of the absence of fall-through in PSL, there is little need to use the last statement in the switch statement.
PSL Statements
3-29
The following similarities exist between the PSL switch statement and the C switch statement: Both generate a compiler error upon detecting two default labels in a single switch statement. Both permit nested switch statements.
Because of the similar method of implementation, there is almost no difference in efficiency between PSL switch statements and if-then-elsif sequences. Programming style is the main consideration in the choice. To speed up switch statements, BMC Software recommends that you specify the most likely cases first. The speedup is also true of if-then-elsif sequences.
Pitfall: switch Statement case Labels That Modify case Variables
All expressions within a comma-separated list are evaluated before the case label. This evaluation occurs even if the first expression is a match. This sequence and method of evaluating the case label can be a dangerous pitfall if any expression in the list modifies either variable for the current switch statement or a variable used in another case expression.
3-30
Pitfall: Statements Inside a switch Statement That Are Not Part of a BLOCK
Under PSL, statements within a switch statement that are not part of a BLOCK (free statements) can and will be executed if they are reached by the flow of execution. The condition for control flow to reach these statements is that variable cannot match any of the case labels that precede them within the switch statement. BMC Software views free statements within a switch statement as a potential pitfall and recommends that you avoid doing so because it may not be supported in future PSL releases.
Pitfall: Nesting case Labels That Use the Same Variable
PSL does not return a warning or error message when two case labels evaluated against expression are nested one inside the other. Two examples of this situation are shown in the following PSL switch example:
switch(x) { case 1: { f1() case 2 : {f2();} f3(); } default: {case 4: {f4();}} }
Since case and default labels are run-time statements, the effect of one case label nested within another is that expression must match the case value for the case BLOCK to execute. This means that expression must equal two different values! In case 1 of the example, f2 will never be called because x cannot equal both 1 and 2. In the default case of the example, f4 will be called if expression = 4 because there is no case 4 defined in the switch statement. When expression = 4, the default BLOCK executes, containing the case 4 BLOCK call to function f4.
PSL Statements
3-31
Although nesting case labels within one another is possible and may have some utility, BMC Software views them as a potential pitfall both because of the possibility of creating unreachable BLOCKs and because future PSL versions may not support case label nesting.
3-32
while
Format
while (expression) {BLOCK}
Parameters
Parameter expression BLOCK Definition
A PSL statement whose evaluation returns either TRUE or FALSE One or more PSL statements that execute repeatedly as long as expression evaluates to TRUE
Description
The while loop executes statements as long as expression evaluates to TRUE (non-zero).
Example
The following sample PSL statements print the integers from 1 to 10.
x = 1; while (x <= 10) { print (x, " "); x++; } print ("\n");
PSL Statements
3-33
3-34
4
4 4
The PSL built-in functions allow you to write powerful and efficient scripts that rarely require access to the operating system. Several Unix operating system functions are included in the PSL built-in functions so that PSL execution can occur within the PATROL Agent process space.
4-1
Function
Definition
Page
Application Discovery:
full_discovery() in_transition() proc_exists() process() Verify whether the PSL script is in a full discovery cycle Allow time for an object to change states Verify the existence of a process on the system Return a list of processes in the PATROL Agent process cache 4-134 4-160 4-213 4-214
Command Execution:
chan_exists() close() desktop() execute() fopen() get_chan_info() internal() popen() share() system() Verify that a process or file I/O channel exists Close a channel created by the popen function Execute a PATROL link command within the Console Submit command to a command processor Open a channel to a file Return channel information Execute command within the PATROL Agent Open a channel to a process Convert a local channel to a shared global channel Submit a command to the operating system 4-32 4-39 4-64 4-115 4-126 4-136 4-158 4-201 4-321 4-389
Condition Variable:
cond_signal() cond_wait() Send a condition variable to unblock a process Block a process while waiting for a condition variable 4-41 4-42
Debugging:
debugger() Suspend process and wait for attach from the PSL Debugger 4-63
Environment:
getenv() Return the value of an object environment variable 4-140
4-2
Table 4-1
Function
Definition
Page
Event Management:
event_archive() event_catalog_get() event_check() event_query() event_range_manage() event_range_query() event_report() event_schedule() event_trigger() event_trigger2() Write selected PATROL events to an archive file Return information from a PATROL event catalog Count specific PATROL Event Manager events Return specific PATROL Event Manager events Change the state of a range of event IDs Return the events with a specified range of event IDs Return statistics for events matching the specified filter Schedule a PATROL event Create an event instance Create an event instance with a specified origin 4-75 4-81 4-84 4-88 4-95 4-97 4-99 4-104 4-111 4-113
File Handling:
cat() file() fseek() ftell() remove() Return the contents of a file as a single string Test for file existence and return the last modification time of the file Set file position Return current file position Remove a file from the file system 4-29 4-122 4-130 4-132 4-250
Input/Output:
chart() log() popup_report() print() printf() read() readln() sprintf() tmpnam() write() write_to_report() Load, destroy, or print a chart on the PATROL Console Send an information event to the PATROL Event Manager Pop up a task window on interested Consoles Return format string to a PATROL Console computer system window Display output using C language formatting conventions Return data read from an open channel Return a line of data read from an open channel Return format string to the specified destination Return a unique temporary file name character string Write data to an open channel Write arbitrary text to a popped-up task window 4-35 4-172 4-203 4-208 4-209 4-222 4-224 4-378 4-398 4-415 4-417
Locking:
destroy_lock() lock() unlock() Destroy a PSL process lock and wake blocked processes Request a PSL process lock Release a PSL process lock 4-66 4-169 4-408
4-3
Table 4-1
Function
Definition
Page
Mathematical:
acos() asin() atan() ceil() convert_base() cos() cosh() exp() fabs() floor() fmod() int() loge() log10() pow() random() sin() sinh() sqrt() srandom() tan() tanh() Return the arccosine trigonometric function Return the arcsine trigonometric function Return the arctangent trigonometric function Return the smallest integer not less than the argument Convert a number from one base to another Return the cosine trigonometric function Return the hyperbolic cosine function Return the natural base e raised to a power Return the absolute value of a floating point number Return the largest integer not greater than the argument Return the remainder of a floating point division Return the integer portion of a number Return the logarithm with respect to base e Return the logarithm with respect to base 10 Return the value of a number raised to a power Return a pseudorandom number Return the sine trigonometric function Return the hyperbolic sine function Return the square root Seed the pseudorandom number generator Return the tangent trigonometric function Return the hyperbolic tangent function 4-8 4-19 4-20 4-31 4-47 4-52 4-55 4-120 4-121 4-124 4-125 4-157 4-173 4-175 4-206 4-220 4-323 4-325 4-383 4-385 4-393 4-395
Object Manipulation:
blackout() change_state() create() destroy() exists() get() get_vars() is_var() set() unset() Hide PATROL object state changes for a period of time Change the state of an object Add a new application instance Delete an existing application instance Verify whether the object exists Return the current value of a variable List the variables associated with an object Return whether an object is a variable Specify the value of a variable Remove an object assigned using the set() function 4-24 4-33 4-57 4-65 4-118 4-135 4-148 4-164 4-316 4-410
4-4
Table 4-1
Function
Definition
Page
PATROL Agent:
pconfig() Manage PATROL Agent configuration variables 4-189
PATROL Console:
console_type() num_consoles() Return 1 if the Console is a PATROL Developer Console Return the number of consoles accessing this script 4-46 4-187
Process Control:
atexit() getpid() getpname() kill() PslExecute() PslSetOptions() sleep() trace_psl_process() Call a user-defined PSL function upon the normal termination of a process Return the process identifier for the current PSL process Return a PSL process name as per a specified process id Terminate a PSL process Start a PSL process Set the run-time options for the calling PSL process Suspend PSL process execution for a specified number of seconds Enable tracing for a specified process, application, or parameter 4-22 4-142 4-143 4-166 4-217 4-219 4-327 4-401
4-5
Table 4-1
Function
Definition
Page
Sets:
difference() intersection() sort() subset() union() unique() Return a list whose elements are in one list but not others Return a list whose elements are common to all specified lists Sort a list of characters or numbers Verify that one list is a a subset of another Return a list that is the union of individual lists Remove all duplicate elements from a list 4-67 4-159 4-375 4-386 4-405 4-407
SNMP:
snmp_agent_config() snmp_agent_start() snmp_agent_stop() snmp_close() snmp_config() _snmp_debug() snmp_get() snmp_get_next() snmp_h_get() snmp_h_get_next() snmp_h_set() snmp_open() snmp_set() Verify PATROL Agent SNMP support Start the PATROL Agent SNMP support Stop the PATROL Agent SNMP support Close a PATROL Agent SNMP session with the PATROL Console Configure or return parameters from a PATROL SNMP session Activate debugging for SNMP Return variables from the Management Information Base (MIB) Return alphabetically greater variables from the MIB Open a brief session to return variables from the MIB Open a brief session to return alphabetically greater variables from the MIB Open a brief session to return variables from the MIB Open a session with the SNMP agent Set variables in the MIB 4-329 4-331 4-332 4-333 4-335 4-339 4-341 4-343 4-345 4-348 4-351 4-354 4-356
SNMP (continued):
snmp_trap_ignore() snmp_trap_listen() snmp_trap_raise_std_trap() snmp_trap_receive() snmp_trap_register_im() snmp_trap_send() snmp_walk() Stop accumulating incoming SNMP event traps Start accumulating incoming SNMP event traps Raise the standard PATROL trap Receive and return SNMP event traps Maintain a list of SNMP Managers that receive PATROL SNMP traps Send an SNMP trap Return subsequent variables from the MIB 4-373 4-351 4-354 4-356 4-368 4-359 4-360
4-6
Table 4-1
Function
Definition
Page
String Manipulation:
encrypt() grep() index() isnumber() join() length() lines() ntharg() nthargf() nthline() nthlinef() replace() rindex() substr() tail() tolower() toupper() trim() Encrypt a supplied string as per a specified encryption type List all lines that contain a specified pattern Return the character offset of one string within another Determine whether the string is a valid numeric expression Join strings together with a separator between each string Return the length of a text string or block Return the number of lines in a text string or block Return the specified fields from a text string or block Return the specified fields from a text string or block (multiple adjacent delimiters delimit NULL fields) Return the specified lines from a text string or block (skip new-line characters) Return the specified lines from a text string or block Replace a specified string in text with a replacement string Return the position of the last occurrence of one string within another Return a specified portion of a string Return the last lines from a text string or block Return a string with all characters converted to lowercase Return a string with all characters converted to uppercase Return a string with specified characters removed 4-73 4-150 4-156 4-162 4-165 4-167 4-168 4-177 4-180 4-183 4-185 4-252 4-314 4-388 4-391 4-399 4-400 4-403
4-7
acos()
Return the arccosine of the argument
Format
acos(cosine)
Parameter
Parameter cosine Definition
Cosine argument. Valid Range: 1  cosine  1
Description
The acos() function returns the arccosine of cosine; that is, the length in radians of the arc whose cosine is cosine. The output range for the acos() function is 0  acos()  . The acos() function return value is accurate to six decimal places.
4-8
annotate()
Provide contextual information for a PATROL parameter
Format
annotate("parameter","format","data1", . . . ,"datan")
Parameters
Parameter parameter Definition
Name of the parameter for which annotation information is specified. The parameter name can be an absolute path name, or a path name relative to the current or other parameter name. If you specify the NULL string "" or the string ".", the annotate() function uses the current parameter name or the parameter name for which the current recovery script is running.
format
Mnemonic indicating the type of display for the specified annotation information. See Specifying the annotate() Function Output Format on page 4-12 for more information. Valid Range: "%Text" display annotation data as a character string in a text editor window "%InfoBox" display annotation data in the PATROL InfoBox style "%Response" display text as a read-only response() function dialog box Default: "%Text"
datan
One or more optional text strings that specify the annotation information. The datan may have interpreted differently depending on format.
annotate()
4-9
Description
The annotate() function instructs the PATROL Agent to save information represented by datan for parameter in the history database for later viewing as format. The purpose of the annotate() function is to allow a Knowledge Module to annotate a parameter value with contextual information that may allow a user to more readily identify the cause of an unusual condition. The additional information, represented by the datan, is stored historically in the PATROL Agent history database and is subsequently viewable from the PATROL Console, from a PSL script, or through archiving. The PATROL Console user can view annotation information for the current parameter value or historical values. The PATROL Console accesses the annotation information using drill-down on data points or options (depending on the context). The annotation information can presented either as plain text, in a PATROL InfoBox style, or in the form of a PSL response() function dialog.
Annotation and History Retention
The PATROL Event Manager/Agent retains annotations for the same duration as the parameter values that they accompany. Annotations are kept in the history database using the usual history retention settings in the Knowledge Module and PATROL Agent configurations. Annotations are purged when the accompanying parameter value is purged. Thus, when specified, every data point retained in the history database has an accompanying annotation. The annotate() function will succeed even when the history retention is zero because it stores the current annotation in memory with the current parameter value. There is no need to pretext the value of the history_get_retention() function before calling the annotate() function. In this case, however, multiple annotations are not stored, nor are annotations persistent.
4-10
If successful, the annotate() command returns the NULL string and sets the PSL variable errno = 0 (E_PSL_NO_ERROR). Upon failure, the annotate() function returns the NULL string, can return the message FAILED to the computer icon display window, and sets the PSL variable errno. The annotate() function return value lends itself to the usage:
ann_return = annotate(parameter,format); if (ann_return) { print("Error from annotate() : ",ann_return,\n); }
The annotate() function returns the message Cannot find runtime object and sets errno = 103 (E_PSL_NO_RTCELL) when parameter does not exist or is not a parameter object.
annotate is called before any data point generated
The annotate() function returns the message annotate called before any data point generated and sets errno = 115 (E_PSL_ANN_TOO_EARLY) when it attempts to annotate a parameter that has not yet stored a value. This can occur when the annotate() function is called before a set() function can set the parameter value.
Cannot save annotation information
The annotate() function returns the message Cannot save annotation information and sets errno = 116 (E_PSL_ANN_SAVE_FAILED) when an attempt to save the annotation data failed. This can be caused by permission restrictions on the history database. This error can also be the result of an internal PATROL error.
annotate()
4-11
Remember that long annotations will use disk space in the PATROL Agent history annotation database.
format = "%Text" is the default if format = "" is specified. "%InfoBox"  PATROL Console InfoBox Output format = "%InfoBox" causes the annotate() function to treat the datan annotation as PATROL Console InfoBox item strings in the form "tagn\nvaluen"
where tagn is the InfoBox item label and valuen is the InfoBox item label. For example, the following annotate() function causes the PATROL Console to show the annotation data in a two-field PATROL Console InfoBox:
annotate(".","%InfoBox","Tag1\nValue1","Tag2\nValue2");
4-12
"%Response" PSL response() Function Dialog Output format = "%Response" causes the annotate() function to treat the datan annotations as PSL response() function element definitions.
(See response() on page 4-253 for more information about the response() function element definitions.) The response() function dialog generated by the annotate() function is read-only.
annotate()
4-13
annotate_get()
Return the annotation text for a parameter value
Format
annotate_get("parameter","timestamp")
Parameters
Parameter parameter Definition
Name of the parameter for which annotation information is specified. The parameter name can be an absolute path name, or a path name relative to the current or other parameter name. If you specify the NULL string "" or the string ".", the annotate() function uses the current parameter name or the parameter name for which the current recovery script is running.
timestamp
Character string that identifies the timestamp of the parameter value for which annotation information should be returned. (timestamp is the timestamp of the set() function that set the parameter value and not the timestamp of the annotate() function call.) Default: the most recent data point for parameter. (This may not be the same as the most recent call to the annotate() function as there may have been another data point stored by a set() function.)
Description
The annotate_get() function returns the annotation for the parameter value at timestamp. The annotate_get() function has been designed for the more advanced uses of the annotate() function, such as those that require verification of whether an annotation already exists.
4-14
If successful, the annotate_get() function sets the PSL variable errno = 0 (E_PSL_NO_ERROR) and returns the annotation string in the form
arg1\arg2\arg3\ . . . \argn
where the argn are the data arguments specified in the annotate() function that created the annotation. The following are specific annotate_get() function error conditions.
Invalid or Non-parameter Object
The annotate_get() function returns the NULL string and sets errno = 103 (E_PSL_NO_RTCELL) when parameter does not exist or is not a parameter object.
No Annotation for Parameter
The annotate_get() function returns the NULL string and sets errno = 105 (E_PSL_ANN_NO_HISTORY_RETENTION) when parameter is valid but 
timestamp is omitted and no annotations exist for any value of parameter in the PATROL Agent history database timestamp is specified an no annotation exists for the value of parameter at timestamp
annotate_get()
4-15
asctime()
Return the date and time as a character string
Format
asctime(clock,"format")
Parameters
Parameter clock Definition
A reference to the clock or timer whose value should be converted to a character string. The clock is most commonly time(). Optional format specification for the asctime() output string. The following are some common field specifiers for the output format: %a %A %b %B %c %d %E %H %I %j %m %M %n %N %o %p %S %t %U abbreviated weekday full weekday abbreviated month full month local date and time representation decimal day of the month (from 01 to 31) combined Emperor/Era name and year decimal hour in 24-hour mode (from 00 to 23) decimal hour in 12-hour mode (from 01 to 12) decimal day of the year (from 001 to 366) decimal month (from 01 to 12) decimal minute (from 00 to 59) new-line character Emperor/Era name Emperor/Era year equivalent of AM/PM decimal second (from 00 to 59) tab character decimal week of the year: Sunday is the first day of the week; all days preceding the first Sunday of the year are in week 0 (from 00 to 53) %w decimal day of the week: Sunday is the first day of the week (from 00 to 06)
format
4-16
Parameter format
(continued)
Definition
%W decimal week of the year: Monday is the first day of the week; all days preceding the first Monday of the year are in week 0 (from 00 to 53) %x local date representation %X local time representation %y decimal year without century (from 00 to 99) %Y decimal year with century %Z time zone name (if time zone name exists) %% % character Field specifiers may be expressed as [ | 0] field_specifier.p where  0 .p left-justify the field (right-justification is the default) right-justify the field and pad with zeros on the left minimum number of digits to display for decimal fields or the maximum number of characters to display for alphabetic fields. For decimal fields, empty character positions are filled with leading zeros. For character fields, excess characters are truncated on the right.
Default if not specified: 24-character string with the format: Sun Sep 16 01:03:52 1973
Description
The asctime() function returns the date/time of clock as a character string. It is equivalent to the C library asctime() function except that the PSL asctime() function adjusts the value to the local timezone. If format is given, asctime() returns the date/time string in the specified format.
Note
The format field specifiers are equivalent to those used in the C library strftime() function and are dependent on the operating system. Refer to the C programming reference for your operating system for valid format field specifiers.
asctime()
4-17
Example
The following PSL script shows how the asctime() function can translate the computer system time value into a familiar Gregorian date and time.
raw_time = time(); default_output = asctime(raw_time); printf("raw time is %ld, default asctime() output is %s\n",raw_time,default_output); output_with_format = asctime(raw_time,"Day is %A, Month is %B, Time is %X\nTimezone is %Z"); printf("%s\n",output_with_format);
4-18
asin()
Return the arcsine of the argument
Format
asin(sine)
Parameter
Parameter sine Definition
Sine argument. Valid range: 1  sine  1
Description
The asin() function returns the arcsine of sine; that is, the length in radians of the arc whose sine is sine. The output range for the asin() function is /2  asin()  /2.
Example
The following PSL script uses the asin() function to confirm the trigonometric identity Arcsin x + Arccos x = /2.
function main() { PI = 3.141593; HALFPI = PI / 2; print("Arcsine + Arccosine Identity Verification\n\n"); print(" Sine Expected Returned\n"); print("--------- --------- ---------\n"); sine = -0.9; while (sine < 1.0) { printf("%+8.6f %+8.6f %+8.6f\n",sine,HALFPI,asin(sine) + acos(sine)); sine = sine + 0.1; } return; }
asin()
4-19
atan()
Return the arctangent of the argument
Format
atan(tangent)
Parameter
Parameter tangent Definition
Tangent argument. Valid range:   tangent  
Description
The atan() function returns the arctangent of tangent; that is, the length in radians of the arc whose tangent is tangent. The output range for the atan() function is /2  atan()  /2.
4-20
Example
The following PSL script uses the atan() function to verify the trigonometric identity:
x sin ( atan ( x ) ) = ----------------2 1+x
function main() { print("Arcsine(Arctangent) Identity Verification\n\n"); print(" tan() Expected Returned\n"); print("--------- --------- ---------\n"); tangent = -1.5; while (tangent <= 1.5) { expect = tangent / sqrt(1 + pow(tangent,2)); printf("%+8.6f %+8.6f %+8.6f\n",tangent,expect,sin(atan(tangent))); tangent = tangent + 0.1; } return; }
atan()
4-21
atexit()
Specify a user-defined PSL function to be called upon the normal termination of a PSL process
Format
atexit("function_name")
Parameters
Parameter function_name Definition
A string specifying the name of a user-defined PSL function you want to call
Description
Use the atexit() function to specify a user-defined PSL function to be called upon the normal termination of a PSL process. You must define the specified function before the atexit() call, and it must take no arguments. The atexit() function is similar to the C atexit() function. The major difference is that, with the PSL atexit() function, only one function can be executed upon normal termination of the process. The atexit() function returns one of the following values, indicating whether the call succeeded: 0 1 2 3 Success User function not defined User function accepts too many arguments Out of memory
If the return value is non-zero, then the call to atexit() failed and the function will not be called upon normal termination.
BMC Software, Inc., Confidential and Proprietary Information
4-22
Example
The following is an example of the atexit() function:
function my_exit_handler() { # This function must take no arguments and be # defined before the atexit() call. print("Hello from my_exit_handler.\n"); } function main() { print("Before the call to atexit()\n"); atexit("my_exit_handler"); print("After the call to atexit()\n"); }
Note
The PSL compiler might warn that the function my_exit_handler was not called or exported. This warning can safely be ignored.
atexit()
4-23
blackout()
Hide PATROL object state changes for a specific period of time
Syntax
blackout("object","period")
Parameters
Parameter object Definition
Name of the PATROL application or instance that has its state changes hidden. If object is omitted, period must also be omitted. Length of time the PATROL application or instance remains blacked out. If period is specified, object must also be specified. Valid range: A character string in the following format:
period
Description
The blackout() function starts and stops the blacking out of state changes (that is, OK  WARN  ALARM transitions) for an instance or application displayed on the PATROL Console. The effect of the blackout() function is similar to that of the Alarm Snooze option on the PATROL Console object menus. However, while the Alarm Snooze option clears alarm states for the specified period on a specific console, the blackout() function preserves the current state of the object for the specified period on all consoles because it is applied at the agent.
BMC Software, Inc., Confidential and Proprietary Information
4-24
When the blackout() function is specified for an object that is currently not available but will be online in the future, the blackout will take effect immediately upon the creation of the object. The blackout() function performs the following actions depending on how you specify its parameters: The blackout() function with no parameters returns a list of all PATROL objects that are currently blacked out. The object names in the returned list are separated by newline characters (\n). The blackout("object") function where object is an instance returns the blackout status for single instance as the following character string: instance\n blackoutend Where instance is the instance name and blackoutend is the system time when the blackout is to end. The blackout("object") function where object is an application returns the blackout status for all instances that belong to the application as the following character string: instance\n blackoutend\n instance\n blackoutend\n ... ... instance\n blackoutend
blackout()
4-25
Where instance is the instance name and blackoutend is the system time when the blackout is to end. The blackout("object","period") function sets the blackout for object to period and returns the string OK if successful. When the requested object is an application, the blackout() function will blackout all instances that belong to the application and reset any existing blackout periods for this application to the requested period. If an application is blacked out, the blackout() function can be applied to an instance belonging to the application, but the blackout period may only be increased. The blackout period for an instance cannot be shorter than the blackout period of its application. The blackout("object","") function ends the blackout of object and returns the string OK if successful. The blackout of an instance cannot be ended if its application has a blackout in effect. If an instance has a longer blackout period than its application, and the blackout is ended for the instance, the blackout period will be reset to the applications blackout period.
4-26
Example
The following examples demonstrate how the blackout() function performs differently when the object is an instance and when it is an application.
Instance
The following PSL statements use the blackout() function to perform the following operations: set a blackout for an instance list all instances that are blacked out return the blackout information for an instance end the blackout for instance
function main() { instance = "/FILESYSTEM/tmp_mnt-home-dherr"; print("Test instance is ",instance,"\n"); print("Blacking out instance . . . ",blackout(instance,"00:00:05"),"\n"); print("Return all blacked out objects . . .\n",blackout(),"\n"); print("Return blackout information for ",instance,"\n"); output = blackout(instance); instance_name = nthlinef(output,1); blackout_time = nthlinef(output,2); print(" Instance : ",instance_name); print("Blackout Expires : ",asctime(blackout_time),"\n"); print("End blackout for ",instance," . . . ",blackout(instance,""),"\n"); }
blackout()
4-27
Application
The following PSL statements use the blackout() function to perform the following operations: set a blackout for an application list all applications that are blacked out return blackout information for an application end the blackout for application
function main() { application = "/FILESYSTEM/"; print("Test application is ",application,"\n"); print("Blacking out application . . . ",blackout(application,"00:00:05"),"\n"); print("Return all blacked out objects . . .\n",blackout(),"\n"); print("Return blackout information for ",application,"\n"); output = blackout(application); for(i =1; i < lines(output); i+=2) { instance_name = nthlinef(output,i); blackout_time = nthlinef(output,i+1); print(" Instance : ",instance_name); print("Blackout Expires : ",asctime(blackout_time),"\n"); } print("End blackout for ",application," . . . ",blackout(application,""),"\n"); }
4-28
cat()
Return the content of a file as a single text string
Format
cat("filename")
Parameters
Parameter filename Definition
Name of the file whose contents are to be returned
Description
The cat() function returns the contents of file filename as a single string or the NULL string on error. Newlines are preserved so that the foreach statement can be used to process the returned string as a list of the lines in filename. The cat() function will set the PSL errno variable in the following situations: Insufficient file privileges: File not found: Could not open file: Memory allocation failure: Read error: errno errno errno errno errno = E_PSL_FOPEN_BAD_ACCOUNT = E_PSL_FILE_NOT_FOUND = E_PSL_FILE_CANNOT_OPEN = E_PSL_CAT_MEMORY_FAILURE = E_PSL_CAT_READ_ERROR
cat()
4-29
Example
The following PSL statements list the names of users listed in the Unix system password file.
people = cat("/etc/passwd"); foreach person (people) { name = ntharg(person, 1, ":"); print("name of person is:", name, "\n"); }
4-30
ceil()
Return the smallest integer that is not less than the argument
Format
ceil(argument)
Parameter
Parameter argument Definition
Numeric argument whose least integer upper bound is to be determined
Description
The ceil() function returns the smallest integer that is not less than argument; that is, the least integer upper bound for argument. The ceil() function and the floor() function together bracket argument such that the following are true: If argument is an integer: ceil(argument) = argument = floor(argument) If argument is not an integer: floor(argument) < argument < ceil(argument) and ceil(argument) = floor(argument) + 1
Example
The following example shows how to use the ceil() function:
any_float = 8.4; ceil_any_float = ceil(any_float); printf("Ceiling of %f is %d\n",anyfloat,ceil_any_float);
ceil()
4-31
chan_exists()
Verify that a process or file channel exists
Format
chan_exists(channel)
Parameter
Parameter channel Definition
The process or file I/O channel name (shared channels) or number (local channels) that is being verified
Description
The chan_exists() function returns 1 if the local or shared channel exists and 0 if it does not. The chan_exists() function return value can be used with condition variables for synchronizing one PSL process to wait until another has opened a channel using either the popen() or fopen() function.
Example
The following PSL statements use the chan_exists() function to verify that a process channel successfully opened:
chan = fopen("/etc/passwd","r"); if (chan_exists(chan)) { print("Channel successfully opened\n"); } else { print("Error opening file\n"); } close(chan);
4-32
change_state()
Change the rule state of a PATROL application instance
Format
change_state("object",state,"description")
Parameters
Parameter object state Definition
Name of the application instance whose state is to be changed Operational state to which object will be set. The valid states are     OFFLINE OK WARN ALARM
description
Optional text string that can be used to explain the state change action. The text string must be enclosed in double quotation marks. The text string is recorded in the Event Diary of the State Change Event in the Event Manager. Default if not specified: NULL string
Description
The change_state() function changes the rule state of application instance object to state. The change_state() function returns the new state or the NULL string on error.
change_state()
4-33
You should never use the change_state() function to set the state of the parent object.
Example
The following PSL statement changes the state of object person to the ALARM state and issues a message to the Event Manager Event Diary.
# change state of instance <person> change_state(person,ALARM,"User close to process quota");
4-34
chart()
Pop up a chart (graph) on the Console, or destroy or print a chart
Format
chart(command,gdf_string,id)
Parameters
Parameter command gdf_string id Definition
Built-in constants (symbolic names). Must be one of CHART_LOAD, CHART_DESTROY, or CHART_PRINT. A string describing the chart. See the description of the GDF (Graph Definition Format) syntax on page 4-37. Optional name identifying the chart on the Console Default if not specified: NULL string
Description
The chart() function displays a chart (also called a graph) on the Console. You specify the contents for the chart in a GDF (Graph Description Format) string. See the description of the GDF syntax on page 4-37. The chart() function performs the following three operations. Load a chart To load a chart, invoke the chart() function using one of the following formats:
id = chart(CHART_LOAD, gdf_string);
or
chart()
4-35
The return value id is the handle for the chart and is required for the following operations: Destroy a previously loaded chart For example,
chart(CHART_DESTROY,"",id);
Upon failure, the chart() function returns 0 and sets the PSL errno to one of the following values: E_PSL_NO_SUCH_ID if id was not supplied and was required E_PSL_BAD_CHART_COMMAND if an invalid command was supplied
Example
The following example shows how you can build a GDF string for a specified chart and how to load, print, and then destroy that chart.
#chart_example.psl # Build the GDF string ct="ChartTitle: Chart Example ONE -- Static Data\n"; x="XAxisLabel: Time\n"; y="YAxisLabel: %\n"; d1="StaticData2D:CPU for hostname sundown: 836586286 10.5, 836586386 20.4, 83658 6486 7.90,836586586 20, 836586686 13, 836586786 0, 836586886 15\n"; d2="StaticData2D:CPU for hostname kokomo: 836586287 1.5, 836586388 61.4, 8365864 83 9.90,836586587 40, 836586688 53, 836586786 0, 836586889 25\n"; d3="StaticData2D:Memory for hostname sundown: 836586286 10.5, 836586386 29.4, 836586486 98.90,836586586 40, 836586686 13, 836586786 60, 836586886 75\n"; gdf_string = ct.x.y.d1.d2.d3; # Load the chart id = chart(CHART_LOAD,gdf_string); # Give the chart a little time to pop up sleep(2);
BMC Software, Inc., Confidential and Proprietary Information
4-36
# Print the chart chart(CHART_PRINT,"",id); # Destroy the chart chart(CHART_DESTROY,"",id); # Build another GDF string ct = "ChartTitle: Chart Example TWO - Feeding on PATROL PARAMETERS\n"; x = "XAxisLabel: Bananas\n"; y = "YAxisLabel: Ping Pong Balls\n"; # nebula is my PATROLAGENT machine d1 = "PatrolConsole:nebula,/FILESYSTEM/root/FSCapacity\n"; d2 = "PatrolConsole:nebula,/CPU/CPU/CPUCpuUtil\n"; gdf_string = ct.x.y.d1.d2; id = chart(CHART_LOAD,gdf_string);
chart()
4-37
GDF Example
An example GDF for the "Static2D" case could look like this:
ChartPlugIn: Static2D ChartWindow: Data Analysis from Patrol 3.1 !Here is a comment: !Use current directory file named "abc.ctf" as template file, !but the keyword is optional. ChartTemplate: abc.ctf ChartTitle: Patrol CPU and Memory Usage Projection ChartXAxisLabel: Time from Jan 1996 to July 1996 ChartYAxislabel: % !Then add chart data CPU for hostname sundown: 836586286 10.5, 836586386 20.4, 836586486 7.90, \ 8365 86586 20, 836586686 13, 836586786 0, 836586886 15 CPU for hostname kokomo: 836586287 1.5, 836586388 21.4, 836586483 9.90, \ 83658 6587 20, 836586688 13, 836586786 0, 836586889 15 Memory for hostname sundown: 836586286 10.5, 836586386 20.4, 836586486 \ 7.90, 836586586 20, 836586686 13, 836586786 0, 836586886 15
4-38
close()
Close a file or process channel
Format
close(channel,flags)
Parameters
Parameter channel flags Definition
The process or file I/O channel name (shared channels) or number (local channels) that is to be closed Optional bit flags used to control close execution. The following bits are used:  Bit 1= 1 indicates that any system process associated with the channel (that is, the PSL fopen() or popen() function) should be killed while closing the channel  Bit 2 = 1 indicates that the channel should be closed even if another PSL process is blocked waiting for a read(), readln(), or write() function. Bit 2 applies only to global channels and is ignored by local channels. Default if not specified: Bits 1 and 2 are both zero.
Description
The close() function closes a channel to a process or command previously created by a fopen() or popen() call. When flags is not specified, the default is zero.
close()
4-39
When bit 1 = 0, the close() function does not kill any processes spawned as a result of the fopen() or popen(); and these processes are allowed to continue. This feature of close() allows you to open a channel to a PSL process, send additional data, and close the channel while allowing the process to complete. When bit 2 = 1, the close() function will close the channel even if another PSL process is blocked pending an I/O request on that channel. When blocking occurs, close() causes the blocked function to wake and receive an error return and errno from the process to which the channel was opened. The close() function returns the NULL string if the closure was successful and 1 with the PSL variable errno set if the closure was unsuccessful. The close() function fails when bit 2 = 0 and channel is a global channel with at least one blocked PSL process.
Example
This example closes the channel that is represented by chan:
close(chan); close(chan,1); close(chan,2); close(chan,3);
# bit 1 set # bit 2 set (2 is binary 10) # both bits set (3 is binary 11)
4-40
cond_signal()
Signal a process that is blocked on a condition wait
Format
cond_signal(variable,all)
Parameters
Parameter variable all Definition
Name of the variable that will unblock a process blocked by the cond_wait() function Non-NULL value that directs the cond_signal() function to unblock all PSL processes that are blocked waiting for variable
Description
The cond_signal() function can signal another PSL process that is currently blocked for a cond_wait() function on variable. If all is specified and is not the NULL string, the cond_signal() function will wake all PSL processes that are blocked on variable. If no processes are blocked on variable, the cond_signal() function has no effect. The cond_signal() function can never block and always returns the NULL string.
Example
The following cond_signal() function signals all processes waiting for CV1 to unblock after the process PASSWD_LCK unlocks:
unlock("PASSWD_LCK"); cond_signal("CV1");
cond_signal()
4-41
cond_wait()
Block a process until a condition signal is received
Format
cond_wait(variable,lockname,timeout)
Parameters
Parameter variable Definition
Name of the variable that will end the cond_wait() condition. The variable is issued by the cond_signal() function. The name of the lock the cond_wait() function should attempt to acquire when it receives the correct unblocking variable in the cond_signal() function. If lockname is the NULL string, the cond_wait() function will not attempt to acquire a lock after receiving variable. Optional number of seconds to wait for the receipt of variable before unblocking and releasing lockname. Valid range:  timeout > 0 specifies the timeout value in seconds  timeout < 0 specifies an infinite timeout; only the receipt of variable can unblock the process
lockname
timeout
4-42
Description
The cond_wait() function blocks the current PSL process until either variable is received or until timeout expires. If the PSL process holds lockname when the cond_wait() function is issued, the cond_wait() function releases the lock. When the cond_wait() function receives variable, the cond_wait() function immediately attempts to acquire lockname. If the cond_wait() function returns a 1, it will always hold an exclusive lock on lockname. If the cond_wait() function fails, it will not hold any form of lock on lockname when it returns. If a timeout occurs, the cond_wait() function returns a failure value of 0, sets the PSL errno = 95 (E_PSL_TIMEOUT) and will not hold any lock on lockname.
condition_variable
The parameter variable is the name of the condition variable that the cond_wait() function waits to have signaled by the cond_signal() function. Condition variable names have global scope analogous to locks and shared channels. None of these different global scopes interfere with one another. You can use the same name without conflict for a lock, a shared channel, and a condition variable.
lockname
On entry to the cond_wait() function, the process releases the lock lockname and blocks waiting to be signalled. The lockname should usually be an exclusive lock held by this process; otherwise, run-time error messages may occur (although the cond_wait() function will still try to go ahead and wait for a signal anyway). The cond_wait() function will always block waiting for the cond_signal() function or for timeout.
cond_wait()
4-43
When another PSL process performs a cond_signal() function that wakes this PSL process, the cond_wait() function call will attempt to gain an exclusive lock (if a lock is requested; that is, if lockname is not the empty string) and either return immediately with the lock or join the queue waiting for an exclusive lock on lockname. It is common style to supply lockname because condition variables are almost always shielded by locks. In the cond_wait() function, lockname must be supplied as the NULL string rather than omitted to force the PSL coder to consider whether a lock is needed. The required lockname reduces the number of errors caused by not using a lock when one is needed.
timeout
The behavior of timeout is unchanged regardless of whether the cond_wait() function is waiting for a cond_signal() function or waiting to acquire lockname. If variable or lockname is destroyed before the cond_wait() function is complete, the cond_wait() function returns 0 and sets the PSL errno value but will not hold any lock on lockname. The lock lockname can be the NULL string, in which case variable is considered to have no associated lock; and the cond_wait() function will return success immediately upon being signaled without waiting for any lock.
4-44
Example
The following cond_wait() function waits on the signal CV1 from PASSWD_LCK before attempting to get the lock:
lock("PASSWD_LCK"); while ((ret = cond_wait("CV1","PASSWD_LCK",180)) != 1) { if ((ret == 0) && (errno == 95)) { last; } print("Still waiting....\n"); } if (errno == 95) { print("Timeout before lock was aquired\n"); } else { print("Got the lock\n"); }
cond_wait()
4-45
console_type()
Return 1 if the console is a PATROL Developer Console
Format
console_type()
Description
The console_type() function examines the console for which the PSL script is running and returns a 1 if the console is a PATROL Developer Console, or returns a 0 otherwise.
Example
The following console_type() function prints the type of console from which it is running:
if (console_type()) { print("Developer Console\n"); } else { print("Operator Console\n"); }
4-46
convert_base()
Convert a number from one base to another
Format
convert_base("number","from_base","to_base","sign")
Parameters
Parameter number Definition
The number that is converted from from_base to
to_base
Valid range (in base 10): Signed Unsigned 2147483647 to 2147483647 0 to 4294967295
The base from which number is converted Valid range: 236 The base to which number is converted Valid range: 236 An optional flag to specify if number is signed. If this value is omitted, the default is signed. A non-zero value indicates that the value is unsigned.
Description
The convert_base() function converts a numeric value, number, from one base, from_base, to another base, to_base. The convert_base() function returns an empty string and sets the PSL errno variable in the following situations: One or both base values are out of range: The number value is out of range: Example
BMC Software, Inc., Confidential and Proprietary Information
68 E_PSL_EDOM 69 E_PSL_ERANGE
convert_base()
4-47
The following PSL statements convert a base 10 number supplied by the user to a base specified by the user. This function uses the convert_base() function for the base conversion and the response() function to create a GUI for the user to enter the desired values.
# Response function to input number and desired base string=response( "Base Conversion",-1,["h=100","w=100","b=Patrol","e=1","o=Accept","c=Cancel ","N=0","A=0","B=0"], [R_COLUMN, 4], [R_LABEL_CENTER, "Enter a base 10 number,\nand select a base to convert it to:"], [4], [R_LABEL, " "], [R_TEXT_FIELD_LABEL, "Number", "\n", "e=1"], [R_ROW, 2], [R_LABEL, " "], [R_CLICKER, "Base", 2,36,2] ); # Obtain status, number, and desired base from response function return stat=trim(nthlinef(string,"1"),"\n"); numb=trim(nthlinef(string,"2"),"\n"); base=trim(nthlinef(string,"3"),"\n"); # Verify the return status if the dialog was CANCELLED (0), exit if (stat==0) { exit; # Verify number value is numeric and within range if not display error message dialog } elsif (isnumber(numb)==0 || numb>2147483647 || numb<-2147483647){ response( "Error",-1,["h=100","w=100","b=Patrol","e=1","o=OK","c=Cancel ","N=1","A=0","B=0"], [R_COLUMN, 3], [4], [R_LABEL, " "], [R_LABEL_CENTER, "The value entered\n\n"."(".numb.")"."\n\nis not a valid number, or it is out of range!"] ); exit; # If input is acceptable, compute new value and display output dialog } else { # Use the convert_base() function to convert numb from base 10 to base new=convert_base(numb,"10",base); response( "Conversion",-1,["h=100","w=100","b=Patrol","e=1","o=OK","c=Cancel ","N=1","A=0","B=0"], [R_COLUMN, 3], [4], [R_LABEL, " "], [R_LABEL_CENTER, numb." converted to base ".base." = ".new] ); }
4-48
convert_date()
Convert the Gregorian date and time to the number of seconds that have elapsed since 00:00:00 GMT January 1, 1970
Format
convert_date("day date month year time timezone","timezone") convert_date("day month date time timezone year","timezone") convert_date("day month date time year","timezone")
Parameters
Parameter day date month Definition
Three-character string representing the day of the week. Valid range: Sun Mon Tue Wed Thu Fri Sat Integer day of the month. Valid range: 1  31 Three-character string representing the month. Valid range: Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec Integer year. Valid range: 1902  2037 Eight-character string in the form hh:mm:ss representing the time. Valid range:
year time
hh hours (00  23) mm minutes (00  59) ss seconds (00  59) timezone
Optional time zone for which the conversion is being performed. Valid range:        GMT  Greenwich Mean Time UT  Universal Time EST or EDT  Eastern Standard or Daylight Time CST or CDT  Central Standard or Daylight Time MST or MDT  Mountain Standard or Daylight Time PST or PDT  Pacific Standard or Daylight Time A through I, K through Z  military time zones
convert_date()
4-49
Description
The convert_date() function returns an integer that is the number of seconds past 00:00:00 GMT January 1, 1970 of the specified date and time string. The convert_date() command is capable of parsing any of three date and time string formats:    the RFC-822 format (day, date month year time timezone) the Unix format (day month date time timezone year) the PSL date() function format (day month date time year)
The convert_date() function requires the timezone parameter in order to correctly convert the date and time. If timezone is not specified, either in the date and time string (RFC-822 and Unix formats) or as a separate parameter (all formats), the convert_date() function uses the time zone defined for the machine on which it is executing. If the convert_date() function encounters an error, it returns a zero and sets the PSL errno variable as follows:
errno = 105 (E_PSL_BAD_DATE_STRING) indicates that the convert_date() function could not parse the date and time string errno = 106 (E_PSL_BAD_TIMEZONE) indicates that the convert_date() function did not recognize the specified timezone. errno = 107 (E_PSL_CANNOT_DETERMINE_TIMEZONE) indicates that the convert_date() function is using timezone = GMT because no timezone was supplied and the time zone used by the computer system could not be determined.
Example
The following convert_date() function calls illustrate the different ways to specify the timezone parameter:
# Specify timezone as part of the date and time string seconds = convert_date("Fri Mar 8 11:39:07 CST 1996"); print("Converted time is ",seconds,"\n");
BMC Software, Inc., Confidential and Proprietary Information
4-50
# Specify timezone as a separate parameter seconds = convert_date("Fri Mar 8 11:39:07 1996","CST"); print("Converted time is ",seconds,"\n"); # Use time zone defined in the operating system seconds = convert_date("Fri Mar 8 11:39:07 1996"); print("Converted time is ",seconds,"\n");
In the case where the operating system uses the CST time zone, the output of these PSL statements is:
Converted time is 826306747 Converted time is 826306747 Converted time is 826306747
convert_date()
4-51
cos()
Return the cosine of the argument
Format
cos(radians)
Parameter
Parameter radians Definition
Arc length in radians whose cosine is to be determined Valid range:   radians  
Description
The cos() function returns the cosine of radians. The output range for the cos() function is 1  cos()  1.
4-52
Example
The following example uses the cos() function to draw a crude graph of a cosine waveform over a half period.
function main() { print("Cosine Waveform:\n\n"); print(" -1 -0.5 0 0.5 1\n"); print(" +----+----+----+----+\n"); i = 0.0; while (i <= 3.2) { printf("%4.2f ",i); cosine = cos(i); plot = int(10 * cosine) + 10; if (plot < 10) { before = ""; j = 1; while (j <= plot) { before = before . " "; j++; } after = ""; j = plot; while (j < 9) { after = after . " "; j++; } print(before,"*",after,"|"); printf(" cosine = %+8.6f\n",cosine); } elsif (plot == 10) { print(" *"); printf(" cosine = %+8.6f\n",cosine); } else { print(" |"); before = ""; j = 11; while (j < plot) { before = before . " "; j++; } print(before,"*"); after = ""; j = plot + 1; while (j <= 22) { after = after . " "; j++; } print(after); printf("cosine = %+8.6f\n",cosine); } i = i + 0.1; } }
cos()
4-53
0.00 0.10 0.20 0.30 0.40 0.50 0.60 0.70 0.80 0.90 1.00 1.10 1.20 1.30 1.40 1.50 1.60 1.70 1.80 1.90 2.00 2.10 2.20 2.30 2.40 2.50 2.60 2.70 2.80 2.90 3.00 3.10 3.20
cosine cosine cosine cosine cosine cosine cosine cosine cosine cosine cosine cosine cosine cosine cosine cosine cosine cosine cosine cosine cosine cosine cosine cosine cosine cosine cosine cosine cosine cosine cosine cosine cosine
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
+1.000000 +0.995004 +0.980067 +0.955336 +0.921061 +0.877583 +0.825336 +0.764842 +0.696707 +0.621610 +0.540302 +0.453596 +0.362358 +0.267499 +0.169967 +0.070737 -0.029200 -0.128844 -0.227202 -0.323290 -0.416147 -0.504846 -0.588501 -0.666276 -0.737394 -0.801144 -0.856889 -0.904072 -0.942222 -0.970958 -0.989992 -0.999135 -0.998295
4-54
cosh()
Return the hyperbolic cosine of the argument
Format
cosh(argument)
Parameter
Parameter argument Definition
Numeric value whose hyperbolic cosine is to be determined Valid range:   argument  
Description
The cosh() function returns the hyperbolic cosine of argument. The hyperbolic cosine is defined by the expression:
cosh(x)
= (ex + ex)/2
where e is the base for the natural logarithms (e =2.71828 . . .). The output range for the cosh() function is 1 cosh() .
cosh()
4-55
Example
The following PSL statements use the cosh() function to numerically check the hyperbolic cosine definition.
function main() { print("Test cosh(x) = 0.5 * (exp(x) + exp(-x))\n"); print("over the interval from -5 to 5\n\n"); print(" x cosh(x) 0.5 * (exp(x) + exp(-x))\n"); print("---------- ---------- ------------------------\n"); i = - 5; while (i <= 5) { coshdef = 0.5 * (exp(i) + exp(-i)); printf("%+10.6f %+10.6f %+10.6f\n",i,cosh(i),coshdef); i++; } }
4-56
create()
Create a PATROL object
Format
create("object","label","state","description","parent")
Parameters
Parameter object Definition
An alphanumeric identifier for the object. The object can be either a string (enclosed in double quotation marks) or a variable containing a string and must be unique within the current applications name space. The object parameter is validated using the following rules:  object is composed of name segments separated by a slash (/)  object may start with a slash (/), but not end with a slash(/)  object may not contain empty segments  object may not contain unprintable characters  object may not contain whitespace other than the space character  object may contain spaces within a segment but not at the beginning or end of a segment
label
Optional text string that is used for object identification and icon specification. If no icon is specified in the label, then the label appears below the object's icon. If an icon is specified in the label, then the label is split into two componentsthe label string that will appear under the object's icon, and the name of the icon to be used. Default if not specified: alphanumeric identifier object is used
create()
4-57
Parameter state
Definition
Optional state of the object assigned at its creation. Following are the valid object states:     OFFLINE OK WARN ALARM
Default if not specified: NONE. The objects state is not assigned until you use the change_state function to assign the object a state. The PATROL Console will not display the objects icon until the object has a valid state.
description
Optional text string that can be used to introduce the newly created object. The text string must be enclosed in double quotation marks. The text string is recorded in the Event Diary of the State Change Event in the Event Manager. Default if not specified: NULL string
parent
Optional text string that specifies the parent to which the created object will belong. If no parent is specified, object will not have a parent. If parent is "/", object will be displayed in the PATROL Main Window.
4-58
Description
The create() function creates the PATROL application instance with the identifier object. If label is specified, it is the label that the PATROL Console displays beneath the objects icon. The default label is the object name. The format of the label string is as follows: "instance_name" | ":instance_name:icon_base_name" In both cases, the instance_name will be used as the label for the icon. The icon_base_name specifies the two icons which will be used to show the states of the instance. In the Console, the two icons which are used will be icon_base_name_ok and icon_base_name_warn. The suffix and format are defined by the Console according to the PSL rules, so you do not have to specify the file extension in the label string. If the _ok or _warn icon, or both, is not found, the console will use the icon defined in the APPLICATION class.
Note
The Unix Console uses .xpm icon files, and the NT Console used .bmp icon files. If parent is specified, parent will be the parent instance of object. Thus, The container for parent on the PATROL Console will contain object. When parent is destroyed, object will also be destroyed. If object is allowed to propagate its state, and is in ALARM, the combined state of parent will also be in ALARM.
The create() function returns object if it creates the instance or the NULL string if the instance already exists or an error occurs. If the object parameter syntax is invalid the create() function sets the errno variable to 96 indicating E_PSL_BAD_FUNCTION_PARAMETER.
create()
4-59
Since the PATROL Agent and Console do not share a single hierarchy of application, instance, and parameter, it is possible for a new application instance icon to be missing on the console. When an object is created with the create() function and a parent object is specified, the object id of the parent object is stored it in the application instance structure on the agent which guarantees the parent object exists in the agent namespace, but not necessarily on the console. When the application instance is sent to the console, the agent includes the parent object id, which allows the console to determine where the icon should be located. The icon will be misplaced or not displayed in the following circumstances: The parent object exists in the agent namespace, but does not have an icon in the console. The parent object wont have an icon in the following circumstances: The parent object is in the VOID state. The KM to which the parent object belongs is not loaded on the console The console has not asked the agent for the status of the parent object yet.
The parent object has been destroyed. The KM destroyed the instance via PSL. A developer is downloading a new version of the KM to the agent.
When using the create() function, it is good practice to check if a parent object exists and is not in a VOID state before the object is created.
4-60
Examples
The following examples highlight the usage of the create() function.
Create an Object with a Label, State, and Description
# This object is created in OK condition and thus displayed. create(name, "martin", OK,"User logged in");
create()
4-61
date()
Return the date and time as a 24-character string
Format
date()
Description
The date() function returns the current date and time as a 24-character string in the format:
Sun Sep 16 01:03:52 1973
The date() function is equivalent to the C library ctime(3) function. The date() function is also equivalent to the PSL statement:
asctime(time());
Example
The following examples highlight the usage of the date() function.
Assign the Current Date and Time to a Variable
today = date();
4-62
debugger()
Suspend process pending an attach command from the PSL debugger
Format
debugger()
Description
The PSL debugger() function suspends the current PSL process waiting for an attach command from the PSL debugger. The debugger() function complements options within the PSL debugger that suspend PSL processes. The debugger() function offers a low-level method of stopping a PSL process for debugging before it begins. Although modifying PSL source code to debug a particular script may not be convenient, the debugger() function provides a generalized method whereby all PSL code can be debugged, even if it would normally be executed before the console user has time to raise a PSL debugger window! The suspension of the PSL process occurs regardless of whether a PSL debugger window is active on the console. The only way to restart a PSL function suspended through the debugger() function is through the PSL debugger. Thus, the debugger() function should only be used in non-production versions of Knowledge Modules. If the PSL process is already being processed by the PSL debugger, a call to the debugger() function call has no effect. The debugger() function always returns the NULL string.
debugger()
4-63
desktop()
Send a PATROL link command to the Console for execution
Format
desktop("command","application")
Parameters
Parameter command application Definition
Any PATROL link command you want the Console to execute Optional name of a valid application. Default if not specified: command is sent to all consoles that are interested in the PSL process.
Description
The desktop() function sends a specified PATROL link command to the console for execution. If application is not specified, the desktop() function sends command to all consoles that are interested in the PSL process. If application is specified and is a valid application (that is, the application exists), then the output of command is sent to all consoles that are interested in that application.
Example
The following is an example of the desktop() function:
# Open the FSCapacity parameter of the root instance of the FILESYSTEM # application for the nebula agent. desktop("open nebula:/FILESYSTEM/root/FSCapacity"); # As above, but open it only on those systems that are monitoring the # ORACLE application. desktop("open nebula:/FILESYSTEM/root/FSCapacity","ORACLE");
4-64
destroy()
Destroy a PATROL object
Format
destroy("object","description")
Parameters
Parameter object description Definition
The alphanumeric identifier for the object. The object is assigned when the object is created. Optional text string that can be used to explain why the object was destroyed. The text string must be enclosed in double quotation marks. The text string is recorded in the Event Diary of the State Change Event in the Event Manager. Default if not specified: NULL string
Description
The destroy() function deletes the PATROL application instance object, and returns TRUE on success and FALSE on error.
Example
# destroy object whose name is in variable <name> destroy(name);
destroy()
4-65
destroy_lock()
Destroy a PSL process lock and wake all processes blocked on the lock
Format
destroy_lock(lockname)
Parameter
Parameter lockname Definition
Name of the lock that should be destroyed
Description
The destroy_lock() function destroys lockname that was previously granted to a PSL process and wakes all processes that are blocked on it. (Processes become blocked on a lock through either the lock() or cond_wait() function calls.) The destroy_lock() function returns 1 if it successfully finds and destroys lockname, and 0 if it does not.
Note
The lock() and cond_wait() functions set the PSL variable errno = 114 (E_PSL_LOCK_DESTROYED) if the lock upon which they are blocked is destroyed.
Example
The following destroy_lock() function destroys the lock FOOBAR:
status = destroy_lock("FOOBAR");
4-66
difference()
Return the list of elements that are unique to a specified PSL list
Format
difference(list1,list2,list3,list4, . . . ,listn)
Parameters
Parameter list1 list2 . . . listn Definition
PSL list whose elements are being compared against the elements of all other specified lists One or optionally more lists whose elements are compared against list1
Description
The difference() function returns a PSL list with all elements of list1 that are not in any of the lists list2 . . . listn. If list1 is the NULL list, the result is the NULL list.
list1 may contain duplicates. Duplicates in list1 appear in the return list in same order and number as they appeared in list1, provided that they were not removed by matches with the other lists in the difference() function.
All elements that are returned from list1 remain in the same order in the return list. If the return list is not the NULL set, the returned set is delimited by new-line characters; that is, all set elements end with a new-line character.
difference()
4-67
Example
The following difference() function finds the elements that are unique to list1:
function main() { list1 = [1,2,3,4,5,6,7]; list2 = [3,4,5]; list3 = [4,5,6]; unique1 = difference(list1,list2,list3); print("Elements unique to list1 :\n",unique); }
4-68
dump_hist()
Return the PATROL agent history data for an application, instance, or parameter
Format
dump_hist("outfile","start","end","format","application","instance", "parameter")
Parameters
Parameter outfile Definition
Name and path of the dump_hist() function output file If an outfile is not specified, the output is sent to the PATROL Console.
start
Starting time of the history interval in the format MMddhhmmyyyy where MM=month, dd=day, hh=hours, mm=minutes, and yyyy=year (which is optional) If the start time is not specified, the dump_hist() function starts with the oldest available history.
end
Ending time of the history interval in the format MMddhhmmyyyy where MM=month, dd=day, hh=hours, mm=minutes, and yyyy=year (which is optional) If the end time is not specified, the dump_hist() function ends with the most recent history available.
dump_hist()
4-69
Parameter format
Definition
Control characters that specify the content and format of the output for each data point The format parameter permits the following output control options: %H %A %I %P %t %v %g %c %d %m %y %h %M %s \n \r \t \\ print the agent name print the application name print the instance name print the parameter name print the timestamp in elapsed seconds since midnight 01/01/1970 print the value of history point convert the output time values to Greenwich Mean Time (GMT) print the date and time in the format Wed Jul 1 21:45:56 1998 print the day of month (131) print the month of year (112) print the 4-digit year print the hour (023) print the minutes(059) print the seconds (061) add a newline add a carriage return add a tab print a backslash
If the format is not specified, the default format of "\t%c%v\n" is used with a heading for each parameter containing the agent name, application name, instance name, and parameter name.
application
Character string indicating the application If the application is not specified, the history for every application is returned.
instance
Character string indicating the instance If the instance is not specified, the history for each instance of the application is returned.
parameter
Character string indicating the parameter If the parameter is not specified, the history for each parameter of the instance is returned.
4-70
Description
The dump_hist() function returns the PATROL Agent history data for the specified applications, instances, and parameters. Since it may take a long time to dump the history data, the dump_hist() function dumps five parameters and then gives control back to the CPU for other processes, and after 300 milliseconds, the dump_hist() function returns to the run queue. If the dump_hist() function cannot open the outfile, the process terminates and returns the following message:
Cannot open output file to write
If the dump_hist() function output is sent to the PATROL Console, and the desired output exceeds the buffer size, the process terminates and prints all the data in the buffer followed by this message:
data size exceed buffer size
dump_hist()
4-71
Example
The following PSL statement dumps the history for the CACcachCopyReadHitsPercent parameter to C:\out\dump.txt using the default output format.
outfile="c:\\out\\dump.txt"; start="052000001998"; end="052010001998"; format=""; application="NT_CACHE"; instance="NT_CACHE"; parameter="CACcachCopyReadHitsPercent"; print(dump_hist(outfile,start,end,format,application,instance,parameter));
4-72
encrypt()
Encrypt a supplied string according to the specified encryption type
Format
encrypt(str,"type")
Parameters
Parameter str type Definition
The string you want to encrypt
Specifies the encryption type of str and can have one of the two following values: DES Returns a DES encryption of the supplied str PEM Returns an encryption of str for use in PATROL
Event Manager functions
Description
The encrypt() function encrypts the supplied string str according to the encryption type parameter. The type parameter can have one of two values, "DES" or "PEM". If type is "DES", the function returns a DES encryption of the supplied string str. If type is "PEM", the function returns an encryption of the DES encryption of str. Use the PEM encryption type when using the string in PATROL Event Manager functions, such as remote_open(). If you are running the stand-alone compiler/interpreter, the encrypt() function always returns the empty string "".
Example
The following example shows how to encrypt a string:
BMC Software, Inc., Confidential and Proprietary Information
encrypt()
4-73
# Open a connection to a remote Agent # and prompt for the username and password user_response = response("Username/Password",-1,"w=300,h=150", [R_TEXT_FIELD_LABEL,"Username"], [R_TEXT_FIELD_LABEL,"Password"," ","e=0"]); # Check that the OK button was pressed status = trim(nthline(user_response, 1),"\n"); if (status) { # Extract the username and password username = trim(nthline(user_response, 2),"\n"); password = trim(nthline(user_response, 3),"\n"); # Encrypt the password encrypted_passwd = encrypt(password, "PEM"); # Open the remote connection sess = remote_open(host,port,"PEM",username,encrypted_passwd); }
4-74
event_archive()
Archive PATROL events that match the specified filter criteria
Format
event_archive("filename","operation","separator","format", "start-time","stop-time","status","type","node","origin", "pattern","IDrange","class","severity","max-count")
Parameters
Parameter filename Definition
String that is the name of the file where the archived events are written If the file name begins with a path separator (/ or \ depending on the OS), the event_archive() function assumes that the path name is a full path name. Otherwise, the event_archive() function assumes that the file name is a file in the $PATROL_HOME/log directory.
operation
String that specifies the file access used for archiving events Valid range: W A overwrite existing file contents (if any) append to existing file contents (if any)
separator
Character string used to separate events in the archive file. If "" is specified, the event_archive() function uses the newline character (\n) to separate events.
event_archive()
4-75
Parameter format
Definition
Format string used to present each event entry. See Specifying the event_query() Output Format on page 4-91. Default: "" is equivalent to the string "%s %s %s %s %s %s %s %s\n" where the eight strings returned are (in order):         event ID assigned by the PEM event status event type event timestamp host name that produced the event application class or instance that produced the event text string from the event description field text string from the event diary field
FILTER:
start-time
Time endpoint that specifies the oldest event timestamp that is valid for the event archival Valid range: "" indicating January 1, 1970 at 00:00:00 or one of the following strings:     PSL backward compatible: MMddhhmmyy RFC-822: day, date month year hh:mm:ss UNIX: day month date hh:mm:ss year PSL date(): day month date hh:mm:ss year
day  Sun Mon Tue Wed Thu Fri Sat MM  01 to 12 month  Jan Feb Mar Apr May Jun Jul Aug Sep Oct
Nov Dec
dd or date 01 to 31 hh 00 to 23 mm and ss 00 to 59 year 1902 to 2037 yy 00 to 99. In the PSL compatibility format the current year is used when yy is omitted.
4-76
Parameter stop-time
Definition
Time endpoint that specifies the most recent event timestamp that is valid for the event archival Valid range: "" indicating all event timestamps in the repository or one of the following strings:     PSL backward compatible: MMddhhmmyy RFC-822: day, date month year hh:mm:ss UNIX: day month date hh:mm:ss year PSL date(): day month date hh:mm:ss year
day  Sun Mon Tue Wed Thu Fri Sat MM  01 to 12 month  Jan Feb Mar Apr May Jun Jul Aug Sep Oct
Nov Dec
dd or date  01 to 31 hh  00 to 23 mm and ss  00 to 59 year  1902 to 2037 yy  00 to 99. In the PSL compatibility format the current year is used when yy is omitted. status
Event status that is valid for the event archival Valid range: O A C E D OPEN ACKNOWLEDGED CLOSED ESCALATED DELETED
For example: "O,A,C,D" matches all statuses except ESCALATED "O,A,C,E,D" or "" matches all statuses "O,C" matches only statuses OPEN and CLOSED
event_archive()
4-77
Parameter type
Definition
Event type that is valid for the event archival Valid range: I S E W A R INFORMATION CHANGE_STATUS ERROR WARNING ALARM RESPONSE
For example: "S,E,W,A,R" matches all event types except INFORMATION "I,S,E,W,A,R" or "" matches all event types "W,A" matches only event types WARNING and ALARM
node
Computer system name that is valid for the event archival Valid range: "" indicating all computer systems listed in the PEM repository or a host name character string
origin
Application instance or class name that is valid for the event archival Valid range: "" for all application classes or a character string indicating a specific application instance or class
pattern
Character string within the event description field that is valid for the event archival Valid range: "" indicating any characters or a character string
IDrange
String that defines the range of PATROL event IDs that are valid for the event archival Valid range: x x/y -/y x/"" event ID x event IDs between and including x and y event IDs less than and including y event IDs greater than and including x (empty string) all events
class
Event class that is valid for the event archival Valid range: "" indicating all event classes or a character string specifying a specific event class
4-78
Parameter severity
Definition
Lowest event severity that is valid for the event archival Valid range: A string containing an integer between 1 and 5 with 5 being the most severe or " " indicating that all event severities
max-count
Maximum number of events to write to the file. If more events are available than the max-count, the event_archive() function returns the string max count reached instead of the OK string. Default: 100
Description
The event_archive() function writes PATROL events that match the filter criteria from the PATROL event repository to filename using format and separator. The event_archive() function returns the string OK if successful, or the NULL string if not.
Examples
The following event_archive() function appends events matching the default event filter to the file /tmp/myarchive using a new-line separator and the default format:
event_archive("/tmp/myarchive","A","","");
The following event_archive() function overwrites the existing file $PATROL_HOME/log/myarchive with the event description text for events that match the default event filter. Events written to the file are separated by newline characters.
event_archive("myarchive","W","\n","%{EV_DESC}");
event_archive()
4-79
The following event_archive() function overwrites the existing file $PATROL_HOME/log/myfile with events matching the specified filter. The event_archive() function uses the default separator and format.
event_archive( "myfile", "A", "", "", "", "", "", "", "", "", "", "", "", "2" );
# # # # # # # # # # # # # #
archive file $PATROL_HOME/log/myfile append events to existing file default separator default format any start time any stop time any status any type any node any origin any event description all event IDs any event class event severity 2 or greater
4-80
event_catalog_get()
Return information from a PATROL event catalog
Syntax
event_catalog_get("catalog","class","format")
Parameters
Parameter catalog Definition
Event catalog name whose information should be retrieved. To use the PATROL STANDARD catalog, specify "STANDARD" or "STD". Event class name whose information should be retrieved. Format string used to present event catalog information. See Specifying the event_catalog_get Output Format on page 4-82.
class format
Description
The event_catalog_get() function returns a text string containing information from a PATROL event catalog. The information that the event_catalog_get() function can return includes the following:     expert advice snmp support flag event description text escalation, notification, and acknowledge command scripts
event_catalog_get()
4-81
The event_catalog_get() function macro variables return the same information that appears in the PATROL Developer Console Event Editor dialog box.
Table 4-2 event_catalog_get() Function Macro Variables
Macro Variable
%{EV_ACK_TEXT} %{EV_CTG_DESC} %{EV_ESCL_TEXT} %{EV_EXPERT_ADVICE} %{EV_NOTIFY_TEXT} %{EV_SNMP_SUPPORT}
Definition
Text string from the acknowledge command of this event catalog and class. Text string from the description of this event catalog and class. Text string from the escalation command of this event catalog and class. Text string from the expert advice of this event catalog and class. Text string from the notification command of this event catalog and class. Text from the SNMP support of this event catalog and class. Valid range: NO_TRAP SEND_TRAP
4-82
Examples
The following event_catalog_get() function retrieves the text of the Escalation Command edit window for event catalog ORACLEx and event class ResetCounters:
event_catalog_get("ORACLEx","ResetCounters","%{EV_ESCL_TEXT}");
The following event_catalog_get() function also retrieves the text from the Notification Command edit window and formats each field in order to identify it in the output:
event_catalog_get( "ORACLEx", "ResetCounters", "Escalation: %{EV_ESCL_TEXT}\nNotification: %{EV_NOTIFY_TEXT}" );
event_catalog_get()
4-83
event_check()
Return the number of events in the PATROL Event Manager (PEM) repository that match the specified criteria
Format
event_check("start-time","stop-time","status","type","node", "origin","pattern","IDrange","class","severity")
Parameters
Parameter start-time Definition
Time endpoint that specifies the oldest event timestamp that is valid for the event check. Valid range is "" indicating January 1, 1970 at 00:00:00 or one of the following strings:     PSL backward compatible: MMddhhmmyy RFC-822: day, date month year hh:mm:ss Unix: day month date hh:mm:ss year PSL date(): day month date hh:mm:ss year
day  Sun Mon Tue Wed Thu Fri Sat MM  01 to 12 month  Jan Feb Mar Apr May Jun Jul Aug Sep Oct
Nov Dec
dd or date 01 to 31 hh 00 to 23 mm and ss 00 to 59 year 1902 to 2037 yy 00 to 99. In the PSL compatibility format the current year is used when yy is omitted.
4-84
Parameter stop-time
Definition
Time endpoint that specifies the most recent event timestamp that is valid for the event check. Valid range is "" indicating all event timestamps in the repository or one of the following strings:     PSL backward compatible: MMddhhmmyy RFC-822: day, date month year hh:mm:ss Unix: day month date hh:mm:ss year PSL date(): day month date hh:mm:ss year
day  Sun Mon Tue Wed Thu Fri Sat MM  01 to 12 month  Jan Feb Mar Apr May Jun Jul Aug Sep Oct
Nov Dec
dd or date  01 to 31 hh  00 to 23 mm and ss  00 to 59 year  1902 to 2037 yy  00 to 99. In the PSL compatibility format the current year is used when yy is omitted. status
Event status that is valid for the event check. Valid range: O A C E D OPEN ACKNOWLEDGED CLOSED ESCALATED DELETED
For example: "O,A,C,D" matches all statuses except ESCALATED "O,A,C,E,D" or "" matches all statuses "O,C" matches only statuses OPEN and CLOSED
event_check()
4-85
Parameter type
Definition
Event type that is valid for the event check. Valid range: I S E W A R INFORMATION STATE_CHANGE ERROR WARNING ALARM RESPONSE
For example: "S,E,W,A,R" matches all event types except INFORMATION "I,S,E,W,A,R" or "" matches all event types "W,A" matches only event types WARNING and ALARM
node
Computer system name that is valid for the event check. Valid range is "" indicating all computer systems listed in the PEM repository or a character string indicating a specific computer system name. Application instance or class that is valid for the event check. Valid range is "" for all application classes or a character string indicating a specific application instance or class. Character string within the event description field that is valid for the event check. Valid range is "" indicating any characters or a character string specifying a specific text pattern. String that defines the range of PATROL event IDs that are valid for the event query. Valid range: x x/y -/y x/-/event ID x event IDs between and including x and y event IDs less than and including y event IDs greater than and including x all events
origin
pattern
IDrange
class
Event class that is valid for the event check. Valid range is "" indicating all event classes or a character string specifying a specific event class.
4-86
Parameter severity
Definition
Lowest event severity that is valid for the event archival. Valid range is a string containing an integer between 1 and 5 with 5 being the most severe or " " indicating that all event severities.
Description
The event_check() function returns an integer indicating the number of events found in the PATROL Agent PATROL Event Manager repository that matched the search criteria or a 0 indicating no matching events were found.
Example
The following is an example of the event_check() function:
print( "the number of events matching the filter : " . event_check( # the filter definition follows: "", # events after January 1, 1970 "", # any stop time "O", # only OPEN status "A,W", # only ALARM or WARNING types "", # any computer system name "SYBASE", # only events originating from SYBASE "", # match any description text "120/-", # only events whose IDs are >= 120 "" # any event class "2" # event severity 2 or greater ) . "\n" );
event_check()
4-87
event_query()
Return a list of events in the PATROL Event Manager (PEM) repository that match specified filter criteria
Format
event_query("maxcount","delimiter","format","start-time", "stop-time","status","type","node","origin","pattern", "IDrange","class","severity")
Parameters
Parameter maxcount Definition
String that is the maximum number of events that will be returned in the event query. Specifying the NULL string "" causes maxcount to default to 100 String that is used to separate each event in the list of events returned by the event query. Valid range:  "" indicating that a newline character \n will separate the entries  any valid characters including PSL string literals (see PSL String Literals on page 2-6).
delimiter
format
Format string used to present each event entry. See Specifying the event_query() Output Format on page 4-91 Default: "" is equivalent to the string "%s %s %s %s %s %s %s %s\n" where the eight strings returned are (in order): event ID assigned by the PEM event status event type event timestamp host name that produced the event application class or instance that produced the event text string from the event description field text string from the event diary field
4-88
Parameter
Definition
FILTER:
start-time
Time endpoint that specifies the oldest event timestamp that is valid for the event query. Valid range is "" indicating January 1, 1970 at 00:00:00 or one of the following strings:     PSL backward compatible: MMddhhmmyy RFC-822: day, date month year hh:mm:ss Unix: day month date hh:mm:ss year PSL date(): day month date hh:mm:ss year
day  Sun Mon Tue Wed Thu Fri Sat MM  01 to 12 month  Jan Feb Mar Apr May Jun Jul Aug Sep Oct
Nov Dec
dd or date  01 to 31 hh  00 to 23 mm and ss  00 to 59 year  1902 to 2037 yy  00 to 99. In the PSL compatibility format the current year is used when yy is omitted. stop-time
Time endpoint that specifies the most recent event timestamp that is valid for the event query. Valid range is "" indicating all event timestamps in the repository or one of the following strings:     PSL backward compatible: MMddhhmmyy RFC-822: day, date month year hh:mm:ss Unix: day month date hh:mm:ss year PSL date(): day month date hh:mm:ss year
day  Sun Mon Tue Wed Thu Fri Sat MM  01 to 12 month  Jan Feb Mar Apr May Jun Jul Aug Sep Oct
Nov Dec
dd or date 01 to 31 hh 00 to 23 mm and ss 00 to 59 year 1902 to 2037 yy 00 to 99. In the PSL compatibility format the current year is used when yy is omitted.
event_query()
4-89
Parameter status
Definition
Event status that is valid for the event query. Valid range: O A C E D OPEN ACKNOWLEDGED CLOSED ESCALATED DELETED
For example: "O,A,C,D" matches all statuses except ESCALATED "O,A,C,E,D" or "" matches all statuses "O,C" matches only statuses OPEN and CLOSED
type
Event type that is valid for the event query. Valid range: I S E W A R INFORMATION CHANGE_STATUS ERROR WARNING ALARM RESPONSE
For example: "S,E,W,A,R" matches all event types except INFORMATION "I,S,E,W,A,R" or "" matches all event types "W,A" matches only event types WARNING and ALARM
severity
String containing the integer event severity that is valid for the event query. Valid range is "" for all event severities or an integer from 1 5 (5 being most severe) indicating a minimum severity. Computer system name that is valid for the event query. Valid range is "" indicating all computer systems listed in the PEM repository or a host name character string. Application instance or class name that is valid for the event query. Valid range is "" for all application classes or a character string indicating a specific application instance or class. Character string within the event description field that is valid for the event query. Valid range is "" indicating any characters or a character string.
node
origin
pattern
4-90
Parameter IDrange
Definition
String that defines the range of PATROL event IDs that are valid for the event query. Valid range: x x/y -/y x/-/event ID x event IDs between and including x and y event IDs less than and including y event IDs greater than and including x all events
class
Event class that is valid for the event query. Valid range is "" indicating all event classes or a character string specifying a specific event class. Lowest event severity that is valid for the event archival. Valid range is a string containing an integer between 1 and 5 with 5 being the most severe or " " indicating that all event severities.
severity
Description
The event_query() function returns a list of up to maxcount events found in the PATROL Agent PATROL Event Manager repository that matched the filter criteria. The returned list is formatted as specified by format. The event_query() function returns the NULL string if no events were found in the event repository that match the filter criteria.
event_query()
4-91
PATROL macro variables within the format parameter identify the fields that the event_query() function returns. Table 4-3 describes the macro variables available to the event_query() function.
Table 4-3 event_query() Function Macro Variables (Part 1 of 2)
PEM Macro
%{EV_ACK_TEXT} %{EV_ARG1} %{EV_ARG2} %{EV_ARGS} %{EV_CATALOG} %{EV_CLASS_NAME} %{EV_CTG_DESC} %{EV_DESC} %{EV_DIARY} %{EV_ESCL_TEXT} %{EV_EXPECTANCY}
Definition
Text string from the acknowledge command of this event catalog and class. PATROL Event Manager first dynamic argument PATROL Event Manager second dynamic argument Character string that presents the event arguments separated by tab characters (\t). Name of the PATROL event catalog to which the event belongs. Name of the PATROL event class within the PATROL event catalog to which the event belongs. Text string from the description of this event catalog and class. The text string description that was produced for the event. The text string that was entered into the diary for the event Text string from the escalation command of this event catalog and class. Life expectancy and disposition of the event. Valid range: STORED DEL_IF_CLOSED DEL_IF_INFO DO_NOT_STORE
Text string from the expert advice of this event catalog and class. The user ID of the person who performed the last acknowledge, close, or delete action on the event. A sequential integer identifier assigned by the PATROL Event Manager upon receipt of the event. Name of the event within the PATROL event class. Host name that produced the event. Text string from the notification command of this event catalog and class.
4-92
Table 4-3
PEM Macro
%{EV_NSEVERITY} %{EV_ORIGIN} %{EV_OWNER}
Definition
Numeric severity of the event. Event severity is predefined for all event classes in the STANDARD catalog. Application instance or class that produced the event. User ID that owns the event. Default: PATROL account user ID
%{EV_SNMP_SUPPORT}
Text string from the SNMP support of this event catalog and class. Valid range: NO_TRAP SEND_TRAP
%{EV_STATUS}
%{EV_TIME}
Time stamp indicating the system clock time at the moment the event was produced. The timestamp is a 24-character string with the format: Sun Sep 16 01:03:52 1973
%{EV_TYPE}
Event type. Valid range: INFORMATION STATE_CHANGE ERROR WARNING ALARM RESPONSE
Example
The following is an example of the event_query() function:
print( "The result of the query" . event_query( "100", # return a maximum of 100 events "\n\n" # use two newline characters to separate each event # return ID, type, and description "event id: %{EV_ID}\nevent type: %{EV_TYPE}\nevent description: %{EV_DESC}\n", # filter definition starts here:
BMC Software, Inc., Confidential and Proprietary Information
event_query()
4-93
"", "", "O", "A,W", "", "", "", "-/-", "" "" ) . "\n" );
# # # # # # # # # #
any start time any stop time only OPEN status only ALARM and WARNING types any node any origin match any description text match any event ID match any event class match any event severity
4-94
event_range_manage()
Change the status of PATROL events in a specified event ID range
Format
event_range_manage("maxcount","newstatus","username", "IDrange")
Parameters
Parameter maxcount Definition
String that is the maximum number of events that will be affected by the status change. Specifying the NULL string "" causes maxcount to default to 100. String that is the new status to be assigned to each event. Valid range: ACKNOWLEDGED CLOSED DELETED
newstatus
username
String that is the user name of the person changing the event status. The username is placed in each event diary. String that is the range of PATROL event IDs eligible for this event_range_manage() function. Specify IDrange as follows: x x/y -/y x/-/event ID x event IDs between and including x and y event IDs less than and including y event IDs greater than and including x all events
IDrange
event_range_manage()
4-95
Description
The event_range_manage() function assigns newstatus to maxcount PATROL events whose event IDs are within IDrange and writes username in the event diary for each of the modified events.
Note
Choose the value of maxcount with care. Large maxcount values cause more work for the PATROL Agent and can impact its performance. Managing events using the event_range_manage() function follow the same rules used for managing events from the PATROL Console or the PATROL Event Manager (PEM) Console. For example, you cannot acknowledge an event that is closed.
Example
The following event_range_manage() function acknowledges a maximum of 15 events whose event IDs are 30 and above. The user ID used to acknowledge the events is Fred.
event_range_manage("15",ACKNOWLEDGED,"Fred","30-");
4-96
event_range_query()
Return PATROL events from a specified event ID range
Format
event_range_query("maxcount","delimiter","format", "IDrange")
Parameters
Parameter maxcount Definition
String that is the maximum number of events that will be returned in the query. Specifying the NULL string "" causes maxcount to default to 100 String that is used to separate each event in the list of events returned by the query. Valid range:  "" indicating the characters "||" will separate the entries  any valid characters including PSL string literals (see PSL String Literals on page 2-6).
delimiter
format
Format string used to present each event returned by the query. The format string for the event_range_query() function is the same as the format string for the event_query() function. See Specifying the event_query() Output Format on page 4-91 for details of the format specification. Default: "" is equivalent to the string "%s %s %s %s %s %s %s %s\n" where the eight strings are (in order): event ID assigned by the PEM event status event type event timestamp host name that produced the event application class or instance that produced the event text string from the event description field text string from the event diary field
event_range_query()
4-97
Parameter IDrange
Definition
String that is the range of PATROL event IDs eligible for this query. Specify IDrange as follows: x x/y -/y x/-/event ID x event IDs between and including x and y event IDs less than and including y event IDs greater than and including x all events
Description
The event_range_query() function returns up to maxquery events from the PATROL Event Manager log whose event IDs are within the range IDrange. Each event returned is formatted according to format, and the list of events is separated using delimiter. The event_range_query() function returns the NULL string if no events were found whose event IDs are within IDrange.
Note
Choose the value of maxquery with care. Large maxquery values cause more work for the PATROL Agent and can impact its performance.
Example
The following is an example of the event_range_query() function:
event_range_query( "100", # return a maximum of 100 events "\n------\n", # separate events by to newline characters and dashes # return ID, type, status, and description "event id: %{EV_ID}\ntype: %{EV_TYPE}\nstatus: %{EV_STATUS}\ndescription: %{EV_DESC}\n", "300/1000" # only events with IDs such that 300 <= ID <= 1000 );
4-98
event_report()
Return statistics for PATROL events that match the specified filter
Syntax
event_report("start-time","stop-time","status","type", "node","origin","pattern","IDrange","class","severity")
Parameters
Parameter start-time Definition
Time endpoint that specifies the oldest event timestamp that is valid for the event report. Valid range is "" indicating January 1, 1970 at 00:00:00 or one of the following strings:     PSL backward compatible: MMddhhmmyy RFC-822: day, date month year hh:mm:ss Unix: day month date hh:mm:ss year PSL date(): day month date hh:mm:ss year
day  Sun Mon Tue Wed Thu Fri Sat MM  01 to 12 month  Jan Feb Mar Apr May Jun Jul Aug Sep Oct
Nov Dec
dd or date 01 to 31 hh 00 to 23 mm and ss 00 to 59 year 1902 to 2037 yy 00 to 99. In the PSL compatibility format the current year is used when yy is omitted.
event_report()
4-99
Parameter stop-time
Definition
Time endpoint that specifies the most recent event timestamp that is valid for the event report. Valid range is "" indicating all event timestamps in the repository or one of the following strings:     PSL backward compatible: MMddhhmmyy RFC-822: day, date month year hh:mm:ss Unix: day month date hh:mm:ss year PSL date(): day month date hh:mm:ss year
day  Sun Mon Tue Wed Thu Fri Sat MM  01 to 12 month  Jan Feb Mar Apr May Jun Jul Aug Sep Oct
Nov Dec
dd or date  01 to 31 hh  00 to 23 mm and ss  00 to 59 year  1902 to 2037 yy  00 to 99. In the PSL compatibility format the current year is used when yy is omitted. status
Event status that is valid for the event report. Valid range: O A C E D OPEN ACKNOWLEDGED CLOSED ESCALATED DELETED
For example: "O,A,C,D" matches all statuses except ESCALATED "O,A,C,E,D" or "" matches all statuses "O,C" matches only statuses OPEN and CLOSED
4-100
Parameter type
Definition
Event type that is valid for the event report. Valid range: I S E W A R INFORMATION CHANGE_STATUS ERROR WARNING ALARM RESPONSE
For example: "S,E,W,A,R" matches all event types except INFORMATION "I,S,E,W,A,R" or "" matches all event types "W,A" matches only event types WARNING and ALARM
node
Computer system name that is valid for the event report. Valid range is "" indicating all computer systems listed in the PEM repository or a character string indicating a specific host name. Application instance or class name that is valid for the event report. Valid range is "" for all application classes or a character string indicating a specific application instance or class. Character string within the event description field that is valid for the event report. Valid range is "" indicating any characters or a character string. String that defines the range of PATROL event IDs that are valid for the event report. Valid range: x x/y -/y x/-/event ID x event IDs between and including x and y event IDs less than and including y event IDs greater than and including x all events
origin
pattern
IDrange
class
Event class that is valid for the event report. Valid range is "" indicating all event classes or a character string specifying a specific event class. Lowest event severity that is valid for the event archival. Valid range is a string containing an integer between 1 and 5 with 5 being the most severe or " " indicating that all event severities.
severity
event_report()
4-101
Description
The event_report() function returns statistics for events in the PATROL event repository that match the specified filter criteria. The event_report() function returns the empty string if no events match the filter.
Example
The following is an example of the event_report() function:
print( "event statistics\n",
BMC Software, Inc., Confidential and Proprietary Information
4-102
event_report( "", "0407101596", "O", "A", "", "SAP", "", "-/-", "" "" ) . "\n" );
# filter definition starts here: # any start time # only events before 04-07-96 10:15 # only OPEN status # only ALARM type # any computer system # only event originating from SAP # any description text # any event ID # any event class # any event severity
event_report()
4-103
event_schedule()
Schedule a PATROL event. When you schedule a PATROL event, you are scheduling the events Notification command (if any) for execution by the PATROL Agent.
Syntax
event_schedule("add","time","origin","catalog","class", "type","severity","argument1", . . . ,"argument20") event_schedule("delete","scheduleID") event_schedule("list") event_schedule("modify","scheduleID","time","origin", "catalog","class","type","severity","argument1", . . . , "argument20") event_schedule("resume","scheduleID","time") event_schedule("suspend","scheduleID")
4-104
Parameters
Parameter scheduleID Definition
Event identifier within the scheduling queue on which the event_schedule() function will act. scheduleID is returned by the event_schedule("add") function. String specifying the time the PATROL Agent will schedule the event in one of the following formats: RFC-822: day, date month year hh:mm:ss timezone Unix: day month date hh:mm:ss timezone year PSL date(): day month date hh:mm:ss year where the valid ranges of the arguments are:
time
day  Sun Mon Tue Wed Thu Fri Sat date  1 to 31 month  Jan Feb Mar Apr May Jun Jul Aug Sep Oct
Nov Dec
hh:mm:ss  00 to 23, 00 to 59, and 00 to 59 year  1902 to 2037 timezone  GMT UT EST EDT CST CDT MST MDT
PST PDT military time zones A to I, K to Z
time must be a minimum of one minute from the time the event is scheduled
origin
Character string containing the application class or instance name that is identified as having created the event. Character string name of the catalog to which the event belongs. The event_schedule() function requires that catalog be previously defined to the PATROL Event Manager. To use the PATROL standard event catalog, specify "STANDARD" or "STD".
catalog
class
Character string name of the class to which the event belongs. The event_schedule() function requires that class be previously defined to the PATROL Event Manager. The event type as displayed in the PATROL Event Manager. Valid range: ALARM WARNING ERROR CHANGE_STATUS INFORMATION
type
event_schedule()
4-105
Definition
Integer value indicating the severity of the event. Valid range: 1  5 (5 is most severe) Arguments passed to the PATROL event description. This function permits a maximum of 20 arguments.
Description
The event_schedule() function handles the scheduling of events in the PATROL Agent. Scheduling an event means inserting it into the PATROL Agent schedule queue for triggering at a specified time. When the event is triggered, its notification command is executed. Scheduling an event implies that you are scheduling the OS or PSL Notification command corresponding to that event for execution. The following topics describe each of the event_schedule() function options.
The event_schedule() Function Add Option
The event_schedule("add") function causes the PATROL Agent to add the specified event to the PATROL Agent schedule queue for triggering at time. The event_schedule("add") function returns scheduleID if successful or the empty string if not.
The event_schedule() Function Delete Option
The event_schedule("delete") function removes the event identified by scheduleID from the PATROL Agent schedule queue. The scheduleID is returned by the event_schedule("add") function. The event_schedule("delete") function returns the string OK if successful, or an error messages string if not.
4-106
The event_schedule("list") function returns a list of events contained in the PATROL Agent schedule queue. The following is a sample of the output from the event_schedule("list") function:
ID 123 126 226 TIME Fri Mar 15 15:57:31 Fri Mar 15 15:57:31 Fri Mar 16 15:57:31 STATUS active suspended suspended
The event_schedule("modify") function modifies the properties of an event in the PATROL Agent schedule queue. The scheduleID is returned by the event_schedule("add") function. The event_schedule("modify") function returns the string OK if successful or an error message string if not.
The event_schedule() Function Resume Option
The event_schedule("resume") function reinstates an event that has been suspended in the PATROL Agent schedule queue. The scheduleID is returned by the event_schedule("add") function. The event_schedule("resume") function returns the string OK if successful or an error message string if not.
The event_schedule() Function Suspend Option
The event_schedule("suspend") function suspends an event in the PATROL Agent schedule queue. The PATROL Agent does not send the suspended event and the event remains in the PATROL Agent schedule queue in the suspended state. The scheduleID is returned by the event_schedule("add") function. The event_schedule("suspend") function returns the string OK if successful or an error message string if not.
event_schedule()
4-107
Examples
Then following examples show different uses for event_schedule().
Schedule Event Notification
The following event_schedule() function adds an event to the PATROL Agent schedule queue:
schedule_id = event_schedule( "add", # schedule a new event "Fri Mar 15 15:57:31", # trigger on 03-15-96 at 3:57 pm "MyOrigin", # origin is MyOrigin "STD", # catalog is STANDARD "41", # class is 41 "INFORMATION", # type is INFORMATION "3", # severity is 3 "myarg" # first dynamic argument is myarg );
The following event_schedule() function deletes the event schedule_id (created in the previous example) from the PATROL Agent schedule queue:
print( "deleting event . . .\n result : " . event_schedule("delete",schedule_id) . "\n") . "\n" );
The following event_schedule() function returns a list of the events in the PATROL Agent schedule queue:
print( "List of Scheduled Events :", event_schedule("list") . "\n" );
BMC Software, Inc., Confidential and Proprietary Information
4-108
As indicated in the comments, this example shows how you can schedule PSL or OS activities using the event_schedule() function.
# # # # # # # # # # This example shows how you can schedule PSL or OS activities using the PSL event_schedule() function. When an event is triggered, the agent executes the Notification command defined in the event catalog. This notification command can be PSL or OS. This is why when you schedule an event, you are basically scheduling its notification command to be executed as a job. In this example I will schedule 6 events: ("STANDARD","EventArchive"). When this event is executed it dumps all events matching the filter into a file
my_date = "Tu Mar 19 14:57:30 1997"; # must be higher than date my_new_date = "Tu Mar 19 15:55:30 1997"; # Must be higher than my_date my_event_catalog = "STANDARD"; my_event_Class = "EventArchive; my_dump_file = "/tmp/events.arc"; # put herre your own event catalog # put here your own event class to schedule # put here desired dump destination
# Schedule 3 events ("STANDARD","EventArchive") # and store their schedule id in sh1, sh2, sh3 # # This example schedule same job. In practice this is useless sh1= event_schedule( "add", my_date, "job1", my_event_catalog, my_event_class, "INFORMATION","3", my_dump_file ); print("add event : ->".sh1."<-\n\n"); sh2= event_schedule( "add", my_date, "job2", my_event_catalog, my_event_class, "INFORMATION","3", my_dump_file ); print("add event : ->".sh2."<-\n\n"); sh3= event_schedule( "add", my_date, "job3", my_event_catalog, my_event_class, "INFORMATION","3", my_dump_file ); print("add event : ->".sh3."<-\n\n"); # List all scheduled events print("list->\n".event_schedule("list")."<-\n\n");
event_schedule()
4-109
# Schedule 3 more events for execution at my_new_date # and store their schedule ids in sh4, sh5, sh6 sh4= event_schedule( "add", my_date, "job4", my_event_catalog, my_event_class, "INFORMATION","3", my_dump_file ); print("add event : ->".sh4."<-\n\n"); sh5= event_schedule( "add", my_date, "job5", my_event_catalog, my_event_class, "INFORMATION","3", my_dump_file ); print("add event : ->".sh5."<-\n\n"); sh6= event_schedule( "add", my_date, "job6", my_event_catalog, my_event_class, "INFORMATION","3", my_dump_file ); print("add event : ->".sh6."<-\n\n"); # Delete job6 and list all jobs print("delete job 6: ->".event_schedule("delete",sh6)."<-\n\n"); print("list->\n".event_schedule("list")."<-\n\n"); # Suspend job 2 and list all jobs print("suspend job 2: ->".event_schedule("suspend",sh2)."<-\n\n"); print("list->\n".event_schedule("list")."<-\n\n"); # Resume job 2 to be executed at my_new_date instead of my_date # List all jobs print("resume job 2: ->".event_schedule("resume",sh2, my_new_date)."<-\n\n"); print("list->\n".event_schedule("list")."<-\n\n"); # Modify job 4 and list all jobs print( "modify job 4: ->". event_schedule( "modify", "4", my_new_date, "new_job4", my_event_catalog, my_event_class, "INFORMATION","5", my_dump_file ) ."<-\n\n" ); print("list->\n".event_schedule("list")."<-\n\n");
4-110
event_trigger()
Create an event instance for the PATROL Event Manager
Format
event_trigger("catalog","class","type","severity", "argument1", . . . ,"argument20")
Parameters
Parameter catalog Definition
Character string name of the PATROL catalog to which the event belongs. You can use any of the following strings to specify the PATROL standard event catalog: "STANDARD" "STD" "0"
class type
Character string name of the event in the class to which the event belongs. The event type as displayed in the PATROL Event Manager. Valid range: ALARM WARNING ERROR CHANGE_STATUS INFORMATION
severity argumentn
Integer value indicating the severity of the event. Valid range: 1 5 (5 is most severe) Arguments passed to the PATROL Event Manager and displayed in the event detailed report. This function permits a maximum of 20 arguments.
event_trigger()
4-111
Description
The event_trigger() function creates an event instance that appears in the PATROL Event Manager. The origin of the event instance is the PSL context under which the event_trigger() function executes. The event_trigger() function assumes that the event catalog and class are already defined. The event_trigger() and event_trigger2() functions are identical except how they identify the event origin:  The event_trigger() function always sets the origin to the context in which it executes. The event_trigger2() function allows you to specify an origin
The event_trigger() function can be used to develop event reporting within PATROL Knowledge Modules.
Example
The following is an example of the event_trigger() function:
event_trigger( "STD", "41", "INFORMATION", "3", "myarg" );
# # # # #
event catalog : STANDARD event class: 41 event type: INFORMATION severity: 3 one dynamic argument
4-112
event_trigger2()
Create an event instance with a specific origin for the PATROL Event Manager
Format
event_trigger2("origin","catalog","class","type","severity", "argument1", . . . ,"argument20")
Parameters
Parameter origin catalog Definition
Character string indicating the application instance or class that originated the event. Character string name of the PATROL catalog to which the event belongs. You can use any of the following strings to specify the PATROL standard event catalog: "STANDARD" "STD" "0"
class type
Character string name of the event in the class to which the event belongs. The event type as displayed in the PATROL Event Manager. Valid range: ALARM WARNING ERROR CHANGE_STATUS INFORMATION
severity argumentn
Integer value indicating the severity of the event. Valid range: 1 5 (5 is most severe) Arguments passed to the PATROL Event Manager and displayed in the event detailed report. This function permits a maximum of 20 arguments.
event_trigger2()
4-113
Description
The event_trigger2() function creates an event instance that appears in the PATROL Event Manager. The origin of the event instance is origin. The event_trigger2() function assumes that the event catalog and class are already defined. The event_trigger2() and event_trigger() functions are identical except how they identify the event origin:   The event_trigger2() function allows you to specify an origin The event_trigger() function always sets the origin to the context in which it executes.
The event_trigger2() function can be used to develop event reporting within PATROL Knowledge Modules.
Example
The following is an example of the event_trigger2() function:
event_trigger2( "myorigin", "ORACLEx", "ResetCounters", "ALARM", "3", "myarg1", "myarg2" );
# # # # # # #
origin: myorigin event catalog: ORACLEx event class: ResetCounters event type: ALARM severity: 3 dynamic argument 1 dynamic argument 2
4-114
execute()
Execute a command or ActiveX script of a specified type
Format
execute("type","text","instance","username","password")
Parameters
Parameter type Definition
Command or script type to execute. The type can be a command or ActiveX script type.
Commands
For commands, type can be one of the following:  OS (operating system)  any valid user-defined command type
Scripts
For scripts, type can be one of the following:
 vbscript  javascript
 any valid user-defined type that supports the Microsoft ActiveX scripting language The script type is prefixed with either % or %@:  % indicates that the text parameter provides the text of the script  %@ indicates that the text parameter provides the path of a file containing the script The script option is only available with the PATROL Agent for Windows NT 4.0.
text
Text or path of the command or script. See PSL Here Documents on page 2-7 for information on using free-form text for commands and scripts. The application instance against which text executes when type is a command. The instance parameter does not apply to the execution of scripts. Default: The application instance that is the nearest ancestor of command
instance
execute()
4-115
Parameter username
Definition
User name under which text executes when type is a command. The username and password together must be a valid account on the PATROL Agent host. The username parameter does not apply to the execution of scripts.
password
Password under which text executes when type is a command. The password and username together must be a valid account on the PATROL Agent host. The password parameter does not apply to the execution of scripts.
Description
The execute() function can either submit a command to a command processor or submit an ActiveX script to the PATROL Scripting Host for execution.
Commands
When the execute() function submits a command to command processor, the command executes and returns any output that it produces to stdout or stderr. The status of command is saved in the PSL variable exit_status. Sometimes it is desirable to submit long-running commands like daemons to run in the background. For more information on submitting commands to run in the background, see the popen() function on page 4-201.
ActiveX Scripts
When the execute() function submits an ActiveX script to the PATROL Scripting Host, the PSL process is suspended, and the script is sent to the PATROL Scripting Host. When the script finishes, the PSL process returns to the PSL run queue for execution.
4-116
Example
The following examples show the two different ways to use the execute() function.
Command Execution
The following example submits an SQL statement to collect data from a table:
# SQL data is returned into the buffer "data" data = execute("SQL", "select * from user_objects");
execute()
4-117
exists()
Verify the existence of a PSL object
Format
exists("object","inherit")
Parameters
Parameter object Definition
The alphanumeric identifier for the object whose existence is being verified. The object is assigned when the object is created. Boolean expression controls whether exists will search the inheritance hierarchy to verify the existence of object:  If inherit = TRUE, do not search the inheritance hierarchy.  If inherit = FALSE and if object is not a reference to an absolute object, search the inheritance hierarchy.
inherit
Description
The exists() function returns TRUE if object exists; FALSE otherwise. The exists() function is useful in application discovery procedures that determine whether a discovered instance has previously been discovered and instantiated in the object hierarchy. The exists() function searches for any PSL object that matches object, including PSL variables, even if the object was not created with the create() function.
4-118
Example
This example checks to see if the user name "jsmith" has already been created:
name = "jsmith"; if (exists(name)) { print(name); } else { print("User name does not exist"); }
exists()
4-119
exp()
Return the base of the natural logarithms e raised to a power
Format
exp(exponent)
Parameter
Parameter exponent Definition
Numeric value to which the natural base e is raised
Description
The exp() function returns the value eexponent where e is the base of the natural logarithms (e = 2.71828 . . .).
Example
The following exp() function calls print a number of useful physical and mathematical constants:
function main() { PI = 3.141593; printf(" e printf(" 1/e printf(" e^2 printf(" log10(e) printf(" pi^e printf(" e^pi printf(" e^(-pi) printf(" e^(pi/2) printf("e^(-pi/2) }
= = = = = = = = =
%7.4f\n",exp(1)); %7.4f\n",exp(-1)); %7.4f\n",exp(2)); %7.4f\n",log10(exp(1))); %7.4f\n",pow(PI,exp(1))); %7.4f\n",pow(exp(1),PI)); %7.4f\n",pow(exp(1),-PI)); %7.4f\n",pow(exp(1),PI / 2)); %7.4f\n",pow(exp(1),-PI / 2));
4-120
fabs()
Return the absolute value of an argument
Format
fabs(argument)
Parameter
Parameter argument Definition
Floating point value whose absolute value is to be determined
Description
The fabs() function returns the absolute value of argument; that is,  
argument if argument  0 argument if argument < 0
Example
The following fabs() function prints the absolute value of -12.3456:
print(fabs(-12.3456));
fabs()
4-121
file()
Test for file existence and return the last modification time
Format
file("filename",enhanced)
Parameters
Parameter filename enhanced Definition
Name of the file whose last modification date is to be returned Optional flag that requests additional file information in the form:
modtime atime ctime mode size numlinks type  modtime is the last modification date expressed as the number of seconds
since midnight, January 1, 1970  atime is the last access time expressed as the number of seconds since midnight, January 1, 1970  ctime is the last change of status expressed as the number of seconds since midnight, January 1, 1970  mode is the file permissions expressed as an octal integer  size is the length of the file expressed as a number of characters  numlinks the number of links to the file within the file system  type is a character string indicating the file type: FILE DIR SPECIAL BLOCK FIFO LINK SOCKET UNKNOWN ordinary user data file directory character special file block special file pipe or FIFO symbolic link socket (not available on all platforms) unknown file type, possibly a LINK or SOCKET on platforms where the Unix stat() function cannot determine the type; that is, where S_ISLINK or S_ISSOCK are undefined
Currently, the value of 1 for the enhanced parameter is only a place holder and any value is valid, but it is recommended that you use a 1 to specify this parameter to accommodate future enhancements to this function.
4-122
Description
The file() function returns the last modification time of file filename as the number of seconds since midnight, January 1, 1970. If the file does not exist, the file() function returns the NULL string. This function is useful for testing the existence of a file.
Note
The file() function return values depend on the operating system and in some cases the file system. Some non-Unix platforms may not return all return values or may return one or more meaningless return values. For a specific platform, the file() function will generally return the same information as the C programming language stat() function. The user does not need permission to read the file but does require search permission on each directory in the path name leading to filename. If the user does not have such permission, the file() function fails and returns the NULL string. When the enhanced parameter is specified, the file() function returns a more detailed string of information.
Examples
The following examples highlight the usage of the file() function.
Print Last Modification Date of the Unix System Password File
print (asctime(file("/etc/passwd"))); # modification time
file()
4-123
floor()
Return the largest integer that is not larger than the argument
Format
floor(argument)
Parameter
Parameter argument Definition
Numeric argument whose greatest integer lower bound is to be determined
Description
The floor() function returns the largest integer that is not greater than argument; that is, the greatest integer lower bound for argument. The floor() function and the ceil() function together bracket argument such that the following are true: If argument is an integer: ceil(argument) = argument = floor(argument) If argument is not an integer: floor(argument) < argument < ceil(argument) and ceil(argument) = floor(argument) + 1
Example
The following floor() function call prints the integer 12:
print(floor(12.3456));
4-124
fmod()
Return the floating point remainder of a division operation
Format
fmod(dividend,divisor)
Parameters
Parameter dividend divisor Definition
The floating point value whose remainder will be returned after being divided by divisor The floating point value that will divide dividend
Description
The fmod() function returns the floating point remainder of the division (dividend)/(divisor).
Example
The following fmod() function will return the floating point remainder from the division 10.3 divided by 3.1 (which is 1):
print(fmod(10.3,3.1) . "\n");
fmod()
4-125
fopen()
Open a PSL channel to a file
Format
fopen("filename","mode")
Parameters
Parameter filename mode Definition
Name of the file to which the PSL channel should be opened The file access mode. Valid ranges: r w open for read truncate to zero length for write or create file for write a open for append to end of file or create for write rb open binary file for read wb truncate binary file to zero length for write or create binary file for write ab open binary file for append at end of file or create binary file for write r+ open for read and write (update) w+ truncate to zero length for read and write or create for read and write a+ open for read and write at end of file or create file for read and write r+b open binary file for read and write (update) w+b truncate binary file to zero length for read and write or create binary file for read and write a+b open binary file for read and write at end of file or create binary file for read and write
4-126
Description
The fopen() function opens a channel to filename that provides the access to filename from within a PSL process. The read(), write(), get_chan_info(), share(), and close() functions apply to channels that have been opened to files. When supported by the underlying operating system, the fopen() function performs security checks to determine whether the user name of the calling process has permission for the request. The valid range of mode is the same as for the ANSI C fopen() function. If the fopen() function is successful, it returns the PSL channel number to filename. A failure to open filename, such as an operating system problem or invalid mode, sets the PSL errno value and causes the fopen() function returns the NULL string without attempting to open the file. The fopen() function behaves much like the ANSI C fopen() function.
File Permission Changes Using Mode a or w
When the target system is running a variant of Unix, opening filename using mode a or w (append or write) will change filename permissions and ownership to be those of the user name of the calling process. The change uses the Unix chmod and chown commands. The new filename permission value is 0644 octal, which is read/write for the process user name and read permission for all other users. When the target system is non-Unix, the file permission changes depend on whether the underlying file system supports the concept of a file owner. If it does, then file ownership is set to the user name of the calling process and write access is restricted to the owner. If it does not, the file will be accessible by any user.
fopen()
4-127
The fopen() function permits binary modes with a b character though there is currently no way within a PSL process to write any form of binary data other than character strings. The fopen() function b mode may be useful on some non-Unix platforms to prevent the conversion of CR/LF pairs back and forth to new-line characters, as performed by some standard C libraries for text files. BMC Software recommends that OS/2 file names be opened in binary mode.
Using the fopen Function with the fseek Function
The fseek() function may not be meaningful for text files on some non-Unix platforms, so specifying + in mode may imply b regardless of whether b is specified. BMC Software recommends that you use the + in mode for the fopen() function whenever you require file positioning using PSL the fseek() function.
Flush a File after Each PSL File Operation
The PSL functions ensure that a file is flushed after every operation so that the well-known bug of doing a write-then-read or read-then-write without an intervening fseek rewind or fflush does not occur in PSL file operations.
4-128
where fifo is the name of the named pipe you wish to open, and read_fifo is the following shell script:
#!/bin/sh # # read_fifo <fifo> # while [ 1 ]; do if [ ! -p $1 ]; then cat <<- EOF cannot open $1 -- no such file EOF exit 1 cat $1 done
You can use the channel number returned by the popen() function as an argument in the read() or readln() functions to retrieve the information the read_fifo shell script has read from the named pipe.
Example
The following fopen() function calls show the different modes in which a file can be opened:
# open a file for reading readchan = fopen("/etc/passwd","r"); # open a file for writing writechan = fopen("/tmp/abc123","w"); # open a file for appending appendchan = fopen("tmp/newtmp123","a");
fopen()
4-129
fseek()
Set the file position indicator
Format
fseek(channel,offset,whence)
Parameters
Parameter channel offset whence Definition
The file I/O channel returned when the file was opened by the fopen() function Number of bytes to be added to whence to obtain the file position Standard point within a file to which offset is added to obtain the new file position Valid range: One of the following integer values: 0 1 2 the beginning of the file the current file position the end of the file
Note
Issuing the fseek() function against binary files with whence = 2 is not meaningfully supported on all platforms.
4-130
Description
The fseek() function sets the filename position indicator to the whence position plus offset bytes. When the fseek() function encounters invalid parameters (either the whence, offset, or both), the invalid parameters default to zero, and the fseek() function raises a run-time error and completes the file seek operation. Normally, after an invalid parameter defaults to zero, the fseek() function completes successfully. The fseek() function returns 0 for success and 1 for failure. For an invalid channel, that is, for a pipe channel instead of a file channel, the fseek() function returns 1, raises a run-time error and sets the PSL errno variable.
fseek and Append File Mode
Using the fseek() function to change the file position indicator in a file opened in append mode; that is, modes a, ab or a+ will not prevent writes to the end of the file using the write() function.
Example
PSL contains no equivalent to the C rewind() function, but the following fseek() function example is the equivalent of the C function rewind(channel):
fseek(channel,0,0);
The following fseek() function moves the file position indicator 100 bytes past its current location:
fseek(chan,100,1);
fseek()
4-131
ftell()
Return the file position indicator
Format
ftell(channel)
Parameter
Parameter channel Definition
The file I/O channel returned when the file was opened by the fopen() function
Description
The ftell() function returns the file position indicator as the integer number of bytes from the beginning of the file. For an invalid channel, that is, a pipe channel instead of a file channel, the ftell() function returns 1, raises a run-time error, and sets the PSL errno variable. The typical result of both the C and PSL versions of the ftell() function is the number of characters written to or read from a file, except on those platforms that perform CR/LF  new-line conversions on text files. However, the value of the ftell() function after executing an fseek() function to the end of file is usually the total number of characters in the file. The following PSL functions change the file position indicator:
     fopen() fseek() read() readln() write()
4-132
The get_chan_info() function does not change the file position indicator. The close() function makes channel invalid.
Example
The following ftell() function call will return the current file position indicator for the channel chan:
print(ftell(chan) . "\n");
ftell()
4-133
full_discovery()
Verify that the process is currently in a full discovery cycle
Format
full_discovery()
Description
The full_discovery() function returns TRUE if the PSL script containing it is an application discovery script and it is currently in a full discovery cycle. Otherwise, the full_discovery() function returns FALSE. A full discovery cycle is done after the PatrolAgents process cache is refreshed. This flag therefore indicates whether the process cache has been refreshed since the last time the script was executed.
Example
The following example tests whether the PSL script is in a full discovery cycle and exits the script if it is not.
# If we are not in a full discovery cycle # we can exit immediately if (!full_discovery()) {exit;}
4-134
get()
Return the current value of a variable
Format
get(variable)
Parameter
Parameter variable Definition
Name of the variable whose current value will be returned
Description
The get() function returns the current value of variable. If variable is a relative name and does not exist in the context of the PSL script, the get() function successively searches each ancestors context until variable is found or until the search fails in the context of the computer.
Example
The following example returns the current status of RDB database Dev.
get ("/RDB/Dev/status");
get()
4-135
get_chan_info()
Return status information from a PSL file or process channel
Format
get_chan_info(channel,flags)
Parameters
Parameter channel Definition
Channel name (shared channels) or number (local channels) that is reported or "" indicating all channels are reported (subject to flags control) Optional integer value representing two binary flags that controls the output of global and local channel information as follows: 1 2 3 global channels only local channels only both global and local channels
flags
Default if not specified: 1 The flags parameter is ignored when the channel parameter is specified.
4-136
Description
The get_chan_info() function returns channel information a string with the following format:
name status details type scope read_pid read_name write_pid write_name Field name Definition
One of the following:  scope=SHARED  channel name  scope=LOCAL  local channel number  scope=""  all shared and local channels
status details
OPEN or CLOSED One of the following: fopen() channel file name that is opened or NONE if no file name is open popen() channel process ID of the external operating system process to which the channel is attached or 1 if the process has terminated
PIPE or FILE SHARED or LOCAL One of the following: Process ID of the PSL process waiting to read from the channel 1 if no process is waiting
read_name
One of the following: Name of the process waiting to read from the channel NONE if no process is waiting UNAVAILABLE if the process name is not available
write_pid
One of the following: Process ID of the PSL process waiting to write to the channel 1 if no process is waiting
write_name
One of the following: Name of the process waiting to write to the channel NONE if no process is waiting UNAVAILABLE if there is a process but the name is not available
get_chan_info()
4-137
The get_chan_info() function returns all the fields for each channel even if they do not apply to the particular channel. When information is returned for more than one channel, the channel descriptions are formatted as a list with one channel per line separated by new-line characters. If the flags parameter is nonnumeric or less than one, the get_chan_info() function produces a run-time warning, and the PSL errno variable remains zero. The get_chan_info() function returns the NULL string under the following circumstances: no channels exist for the given value of flags a bad channel number or name is specified for channel In this case, the get_chan_info() function also sets the PSL errno variable to 40 E_PSL_GET_CHAN_INFO_BAD_CHANNEL.
4-138
Examples
The following example returns descriptions for all global shared channels:
get_chan_info("");
The following example returns descriptions for the local, global, or both local and global channels as controlled by the value of flags:
get_chan_info("",flags);
The following example returns the description of the local or global channel specified by the value of channel:
get_chan_info("channel");
get_chan_info()
4-139
getenv()
Return the string value of a PSL environment variable
Format
getenv(variable)
Parameter
Parameter variable Definition
Name of the object whose value is to be returned
Description
The getenv() function returns the string value of variable in the environment of the PSL script. The variable value can be returned from any of the following places:     the parameters defined environment variables the applications defined environment variables the computers defined environment the environment of the PATROL Agent at the start of its execution
The getenv() function searches the environment tables in stated order and returns the value of the first matching variable.The getenv() function returns the NULL string if variable is not defined and sets the PSL errno variable to a nonzero value. If the getenv() function is successful, it returns the value of variable and sets the PSL errno variable to zero. Hence, you can use errno to distinguish an undefined variable from one that is set to the NULL string.
Note
The getenv() function is not implemented by calling the standard C getenv() function.
BMC Software, Inc., Confidential and Proprietary Information
4-140
Example
This PSL example presents a function that tests whether an environment variable exists.
function is_environment_var_defined(name) { getenv(name); # Throw away return value of getenv return (errno == 0); # errno is only zero if it is set }
getenv()
4-141
getpid()
Return the process identifier for the current PSL process
Format
getpid()
Description
The getpid() function returns the integer PATROL process identifier of the current PSL process.
Example
The following is an example of the getpid() function:
printf("Current PID is : %d\n",getpid());
4-142
getpname()
Return the name of a PSL process with a specified process identifier
Format
getpname(pid)
Parameters
Parameter pid Definition
Optional process identification number. Must be an integer.
Description
The getpname() function returns the name of the PSL process with a specified pid. If you do not specify the pid of the process you are looking for, then getpname() returns the name of the current process that is calling the getpname() function. The empty string, "", is returned by getpname() if there is no process with the specified pid.
Example
The following is an example of the getpname() function:
proc_name = getpname(24); current_proc_name = getpname(); # Returns the name of PSL process 24 # Returns the name of the current PSL # process
getpname()
4-143
get_ranges()
Return the Border, Alarm1, and Alarm2 range settings for a PATROL parameter
Format
get_ranges("param", enhanced)
Parameter
Parameter param enhanced Definition
Name of the PATROL parameter whose Border, Alarm1, and Alarm2 range settings are to be returned Optional flag that requests additional information. When the enhanced parameter is set to 1, the get_ranges() function returns the state associated with the parameters border and alarm ranges. Currently, the value of 1 for the enhanced parameter is only a place holder and any value is valid, but it is recommended that you use a 1 to specify this parameter to accommodate future enhancements to this function.
4-144
Description
The get_ranges() function returns the current settings of the Border, Alarm1, and Alarm2 ranges for param. The current settings of these alarm ranges are based on one of the following:   what is set by set_alarm_ranges(), or the default KM alarm ranges, if set_alarm_ranges() is not called
The get_ranges() function can be used as follows:  get_ranges("param")displays the numeric range information. If you do not want the state information, do not specify a second parameter. get_ranges("param", 1)displays the numeric range information and the state associated with the parameters border and alarm ranges as one of the following: OK WARN ALARM The return value of get_ranges() consists of three lines, each of which defines the range for Border, Alarm1, and Alarm2, respectively. Each line is a space-separated list of six integers and an optional associated state as follows:
active minimum maximum trigger occurrences recovery-actions state Field active Definition
Integer state of the range Active flag. This corresponds to the Active button on the Border or Alarm dialog. Valid range: 0 1 parameter inactive parameter active
minimum
Integer value of the range minimum. This value corresponds to the position of the Minimum slide bar on the Border or Alarm dialog.
get_ranges()
4-145
Field maximum
Definition
Integer value of the alarm range maximum. This value corresponds to the position of the Maximum slide bar on the Border or Alarm dialog. Integer value of the range trigger selection. This value corresponds to the Trigger Alarm field on the Border or Alarm dialog. Valid range: 0 1 2 Immediately on alarm After alarm has occurred n times After all recovery actions fail
trigger
occurrences
Integer value of the range n occurrences. This value corresponds to the position of the n times slide bar and is only valid when trigger = 1 (After alarm has occurred n times). Valid range: 0 99 Integer count of the number of recovery actions defined for the range. This value corresponds to the number of entries in the List of Recovery Actions for the range. The state associated with the border or alarm range. This value is only displayed when the state parameter is specified for the get_ranges() function. Valid values: OK WARN ALARM
recovery-actions
state
4-146
Example
The following script uses the get_ranges() function to return the ranges of a parameter. A user-defined function PrintRangeInfo() is called to print the returned alarm range information.
function PrintRangeInfo(name,range) { local is_active,minimum,maximum,trigger,occurences, recovery_actions; print("Range information for ",name,".\n"); is_active = ntharg(range,"1"); minimum = ntharg(range,"2"); maximum = ntharg(range,"3"); trigger = ntharg(range,"4"); occurences = ntharg(range,"5"); recovery_actions = ntharg(range,"6"); if (is_active) { print("Alarm is active.\n"); } else { print("Alarm is not active.\n"); } print("Lower value is ",minimum,".\n"); print("Upper value is ",maximum,".\n"); if (trigger == 0) { print("Alarm will trigger immediately.\n"); } elsif (trigger == 1) { print("Alarm will trigger after ",occurences," occurences.\n"); } elsif (trigger == 2) { print("Alarm will trigger after all recovery actions fail.\n"); } print("There are ",recovery_actions," recovery actions.\n"); } function main() { ranges = get_ranges("/MEMORY/MEMORY/MEMPageOut"); border = nthlinef(ranges,"1"); alarm1 = nthlinef(ranges,"2"); alarm2 = nthlinef(ranges,"3"); PrintRangeInfo("Border Alarm",border); PrintRangeInfo("Alarm One", alarm1); PrintRangeInfo("Alarm Two", alarm2); }
The following PSL statement uses the get_ranges() function to return the ranges of a parameter including the associated states:
print(get_ranges("/MEMORY/MEMORY/MEMTest","1"));
get_ranges()
4-147
get_vars()
Return the list of variables for a PSL object
Format
get_vars("object","keyword")
Parameters
Parameter object Definition
Optional name of the object whose variables are to be listed Default if not specified: Current object
keyword
Optional keyword that specifies the information that is to be returned for object. Valid range: nodes print nodes only subnodes return subnodes leaves or "" return leaves only (equivalent to the PATROL Version 3.0 function get_vars(object)) all or 1 return all children (equivalent to the PATROL Version 3.0 function get_vars(object,1))
Description
The get_vars() function returns a list of the variables of object or for the current object if object is omitted. The get_vars() function returns the NULL string if object does not exist. The list of object variables is sorted in ascending alphabetical order.
4-148
Example
The following get_vars() function call returns a list of variables for a PSL object. The print() statement prints the variables for the MEMORY object and all children.
print(get_vars("MEMORY","all"));
get_vars()
4-149
grep()
Return the lines from a text block that match a regular expression
Format
grep("regular-expression","text","vtcib")
Parameters
Parameter regular-expression Definition
Character sequence that defines the pattern that the grep function searches for in text. The regular-expression conforms to the regular expressions defined in the Unix ed(1) command and the Unix regexp(5) description. Following is a brief summary of several regular expression characters: ^ $ . * [] [^] \< \> beginning of line end of line match any single character match zero or more repetitions of the preceding match any of the characters contained within match any characters except those contained within match any characters at the beginning of a word match any characters at the end of a word
Word boundaries are delimited by any characters other than the following: A through Z a through z 0 through 9 _
text
Text that is searched for matches to regular-expression. The text variable can be a text string enclosed in double quotation marks or one or more PSL commands that produce text as output.
4-150
Parameter vtcib
Definition
v
reverses the output of the grep() function, causing the grep() function to output all lines in text that do not contain a match for regular-expression. This flag is similar to the Unix grep -v flag. ignore the meaning of special characters in
t i b c
regular-expression
ignore case when searching for regular-expression matches stop searching for regular-expression matches after the first regular-expression match is found return the number of matches of regular-expression found in text
Description
The grep() function returns a list of the lines in text that match regular-expression. The t and v flags may be used either separately or together and may appear in either order.
Note
The grep() function does not perform file I/O. You must use the cat() function for file I/O. For more information about the cat() function, see page 4-29.
Examples
# search for "martin" substring in /etc/passwd all_lines = cat("/etc/passwd"); # fill a buffer with passwd matching_lines = grep("martin",all_lines); # search for csh users in /etc/passwd passwd_file_text = cat("/etc/passwd"); csh_users = grep("/bin/csh",passwd_file_text); non_csh_users = grep("/bin/csh",passwd_file_text,"v"); # search for users who cant log in (* in the password entry) no_login = grep("*",passwd_file_text,"t"); # or... no_login = grep("\\*",passwd_file_text); # escape the * # search for users who can log in login = grep("*",passwd_file_text,"vt"); # or... login = grep("\\*",passwd_file_text,"v");
BMC Software, Inc., Confidential and Proprietary Information
grep()
4-151
history()
Return history information from the PATROL history database
Format
history("parameter","format",number)
Parameters
Parameter parameter Definition
Name of the object whose history should be returned. The expression "" indicates the current parameter.
parameter can be
 the absolute path, such as "/APP/INST/PARAM"  a relative path, such as "." or "../DIFFERENTINST/PARAM"
format
Optional character string inside double quotation marks that specifies the format of each history() function entry. Valid Values: n t v return the number of available data points as the first value in the return list include the time stamp of each entry in the return list include the value of each history entry in the return list
number
Optional numeric value that limits the number of entries the history function will return. Default if not specified: 50
4-152
Description
The history() function accesses the parameter history database and returns a list containing the number of data points available followed by a number of entries. The history() function returns the empty string, produces a run-time error, and sets the PSL errno variable if a bad format character is provided. Because of the defaults provided in the history() function, the following function specifications are equivalent:
history(parameter) history(parameter,"ntv",50)
The history() function will return any of the following formats, depending on which format flags are set:  
number_entries\n if the n flag is set value\n, time\n, or value time\n if the v, t, and vt flags are set
The history() function separates the values of an entry with spaces and successive entries with new-line characters. You can use the nthline(list1) function to get the number of points from the head of the list and also to extract the entries. Entries can be split if necessary into time and data values using the ntharg() function. The entries will be single values if either the t or v flag is absent.
history()
4-153
Example
The following PSL statements return history information for the MEMPageOut parameter from the PATROL history database:
history_information = history("/MEMORY/MEMORY/MEMPageOut","ntv"); number_of_points = trim( nthlinef(history_information,"1"), "\n"); history_points = nthlinef(history_information,"2-"); printf("Number of points %d\n",number_of_points); printf("History points:\n%s\n",history_points);
4-154
history_get_retention()
Return the history retention value of a PATROL object
Syntax
history_get_retention("object")
Parameter
Parameter object Definition
Name of the PATROL object whose history retention value should be returned. PATROL object names are expressed as strings in the form "/application/instance/parameter where application, instance, and parameter are the application class, instance, and parameter names, respectively.
Description
The history_get_retention() function returns the history retention value for object. The history_get_retention() function returns the NULL string and displays a message in the computer icon console window if an error occurs.
Example
The following history_get_retention() function returns the history retention value for the parameter /USERS/USERS/USRNoUser:
print(history_get_retention("USERS/USERS/USRNoUser"),"\n");
history_get_retention()
4-155
index()
Return the starting position of one string within another
Format
index("text","string")
Parameters
Parameter text Definition
Text to be searched for the occurrence of string. The text can be a text string enclosed in double quotation marks, or one or more PSL commands that produce text as output. One or more characters enclosed in double quotation marks that are to be located within text
string
Description
The index() function returns the position (indicated as an integer) in text at which string begins, or 0 if string does not occur in text. The first position in text is position 1.
Example
The following PSL statement uses the index() function to find the position of one string within another:
sentence = "The quick red fox jumped over the lazy brown dogs"; animal = "fox"; print(index(sentence,animal));
4-156
int()
Return the largest integer that is not greater than the argument
Format
int(number)
Parameter
Parameter number Definition
Numeric value or numeric variable
Description
The int() function returns the largest integer that is not greater than number. It is equivalent to the C library floor(3) function.
Example
The following statements use the int() function to return only the integer portion of a real number. Each statement returns the integer 3.
print(int(3.14) print(int(3.48) print(int(3.52) print(int(3.75) print(int(3.99) . . . . . "\n"); "\n"); "\n"); "\n"); "\n");
int()
4-157
internal()
Process a command internal to the PATROL Agent
Format
internal("command")
Parameter
Parameter command Definition
Text string that is the command the PATROL Agent should process.
Description
The internal() function causes the PATROL Agent to process the string command internally and in a platform-specific manner. The internal() function returns the command output if successful. If unsuccessful or if the command is not supported on the specific platform, the internal() function returns the NULL string and sets the PSL variable errno = 104 (E_PSL_NOT_SUPPORTED). The internal() function is designed to be used for user and process monitoring and resource inquires that can be handled inside the PATROL Agent. In these cases, the internal() function is much more efficient than invoking a separate command that requires a call to the PSL interpreter or some other command processor.
Note
The internal() function is proprietary and FOR BMC SOFTWARE INTERNAL USE ONLY. BMC Software does not support its external use.
4-158
intersection()
Return a list containing elements that are common to all specified lists
Format
intersection(list1,list2,list3,list4, . . . ,listn)
Parameters
Parameter list1 . . . listn Definition
Two or more PSL lists that are being evaluated for common elements
Description
The intersection() function returns a PSL list containing the elements that appear in all the lists list1 . . . listn. The returned list is not well-defined and will contain duplicates if duplicates were present in all lists in the same number and order. The elements in the list returned by the intersection function appear in the same order as they were in list1.If any lists are the NULL list, the return value is the NULL list; otherwise all entries in the returned list are terminated by a new-line character.
Example
The following intersection() function call returns the elements that are common to four sets. The common elements are 7 and 11.
list1 = [1,2,3,7,11]; list2 = [4,5,6,7,8,9,10,11]; list3 = [7,11,12,13,14,15,16,17]; list4 = [7,11]; print("common elements are:\n",intersection(list1,list2,list3,list4));
intersection()
4-159
in_transition()
Wait for a PSL object to change state
Format
in_transition("object",timeout)
Parameters
Parameter object timeout Definition
Name of the object that is being checked for transition between states Time in seconds that is allowed for the transition between states
Description
When first called, the in_transition() function sets a timer equal to timeout seconds on application instance object. While the timer is running, subsequent in_transition() function calls return FALSE. After the timer has expired, calls to the in_transition() function continue to return FALSE until the next full discovery cycle, at which time the in_transition() function will return TRUE and reset the timer. The timer is also reset by calls to the PSL change_state() function. (For more information about the change_state() function, see page 4-33.)
4-160
Example
This example PSL script uses the in_tranistion() function to set a 3-minute timer against the ORACLE database instance dev. When the timer expires, the in_transition function waits for the next full discovery cycle and changes the state of dev to ALARM.
# Some database processes APPEAR to be down. # Wait to make sure that the database is not # in the middle of a startup or shutdown. if (!in_transition ("/ORACLE/dev", 180)) { change_state("/ORACLE/dev",ALARM,"Database has crashed."); }
in_transition()
4-161
isnumber()
Verify that a string is a valid numeric representation
Format
isnumber(variable)
Parameter
Parameter variable Definition
String that is to be evaluated as meeting the criteria for a numeric expression
Description
The isnumber() function returns a Boolean value of 1 if variable is a string that is considered valid as a number or 0 if it is not. A valid number has only digits, periods, or minus signs for every character in variable. White space or any other invalid character anywhere in the string causes the isnumber() function to return 0. The isnumber() function returns 0 for the NULL string.
4-162
Example
The following PSL statements use the isnumber() function to examine a list and report which of the elements are numbers. The expression +77 is enclosed in quotes to avoid + being interpreted as an operator.
list = ["0not",34.2,"16.two",37,94,0.3,-2.8,"+77",nonum]; foreach X (list) { if (isnumber(X)) { print(X," is a number.\n"); } else { print("Sorry, ",X," is not a number.\n"); } }
isnumber()
4-163
is_var()
Verify that a PSL object variable exists
Format
is_var("object")
Parameter
Parameter object Definition
Name of the object that is to be verified as a variable
Description
The is_var() function returns TRUE if object exists and is a variable. The is_var() function returns FALSE if  
object does not exist object exists but is not a variable (that is, it is an application instance
or a parameter)
Example
The following PSL statements use the is_var() function to determine if the PSL object /MEMORY/MEMORY.MEMPageOut/value is a variable. (It is.)
object = "/MEMORY/MEMORY/MEMPageOut/value" if (is_var(object)) { print(object," is a variable.\n"); }
4-164
join()
Join the supplied strings together and place a separator between each of the strings
Format
join(separator,str1,str2,...,strn)
Parameters
Parameter separator str1 . . . strn Definition
A specified delimiter used to separate the joined strings Two or more strings (up to 99) that are to be joined
Description
The join() function joins the supplied strings together and places the separator between each of the strings. Use the join() function instead of PSL techniques for common string manipulation. This function takes at least three parameters. The join() function is equivalent to
text = str1 . seperator . str2 . seperator . str3 ...;
Example
filename = join("1","/usr","local","bin");
join()
4-165
kill()
Terminate a PSL process
Format
kill(pid)
Parameter
Parameter pid Definition
Integer PATROL process identifier for the PSL process that is to be terminated. Default if not specified: the process from which the kill() function is called.
Description
The kill() function terminates the PSL process identified by the process identifier pid. If pid is omitted, the kill() function terminates the process from which it is called. The kill() function returns 0 if the requested process was killed or 1 if pid did not exist or the process was not killed.
Example
The following is an example of the kill() function:
kill(4546);
4-166
length()
Return the number of characters in a string
Format
length("text")
Parameter
Parameter text Definition
Text to be counted for character length. The text can be a text string enclosed in double quotation marks, or one or more PSL commands that produce text as output.
Description
The length() function returns the length in characters of text, including new lines.
Example
The following length() function call returns the number of characters in a string.
X = "28 characters in this string"; print(length(X),"\n");
length()
4-167
lines()
Return the number of lines in a string
Format
lines("text")
Parameter
Parameter text Definition
Text to be counted for number of lines (that is, new-line characters). The text can be the name of a text file, a text string enclosed in double quotation marks, or one or more PSL commands that produce text as output.
Description
The lines() function returns the number of new-line characters in text. You can also use the lines() function for returning the length of a list because the items in a list are delimited by new lines.
Examples
In the following example, the lines() function call returns the number of lines in a character string and in a character list:
string = "Jack and Jill\nwent up the hill"; print ("Lines in string: ",lines(string),"\n"); list = [5,"lines","in","this","list"]; print("Lines in list: ",lines(list),"\n");
4-168
lock()
Acquire a PSL process lock
Format
lock("lockname","mode",timeout)
Parameters
Parameter lockname mode Definition
Name of the lock that should be acquired Optional control permitted under the lock. Valid range: s r w x shared reader writer exclusive
Default if not specified: x If the first letter of mode is not s, r, w, or x a run-time error occurs and mode defaults to x (exclusive).
timeout
Optional integer value that specifies the number of seconds before the lock request expires. Valid range: timeout > 0 is the integer number of seconds the lock request is valid timeout = 0 means nonblocking lock request timeout < 0 means infinite timeout period (that is, wait until the lock is released) Default if not specified: Infinite timeout
Description
The lock() function requests a lock with name lockname. The mode of the request specifies either shared (reader) or exclusive (writer) access under the lock. The optional timeout specifies the number of seconds the request is valid.
lock()
4-169
The default behavior of lock() function is to request an exclusive lock with an infinite timeout period. The lock() function returns 1 for success and 0 for failure.
PATROL Locks and PSL
Lock names are global to the PATROL Agent; thus, all PSL processes share the same table of locks different PSL processes can share parameter lock names to perform concurrent actions
There is no way to enforce lock naming scopeBMC Software recommends that lock names in PSL programs be uniquely encoded using the name of the application. This practice will avoid potential clashes with other PSL programs.
Shared Lock Requests
Shared lock requests for a lock that is currently in share mode are grantedunless there is a waiting write request. Giving priority to a waiting write request prevents the lock mechanism from starving write processes.
Requests for Locks Already Held
It is possible to request a lock that you already hold although it is not good style: requesting a lock that you already hold is ignored requesting a shared lock on a lock you already hold with exclusive access is also ignored
Requesting an upgrade to exclusive access of a lock currently held as shared succeeds and upgrades the lock provided you are the only process that is using the shared lock. If you are not the only process using the lock, the lock() function immediately returns 0 in non-blocking mode (regardless of the value of timeout because blocking would cause immediate deadlock by waiting for yourself!).
BMC Software, Inc., Confidential and Proprietary Information
4-170
Rather than using this upgrade feature, BMC Software recommends that you call the unlock() function to release the shared lock before attempting to acquire the new exclusive lock. Lock tracing is possible using the PslDebug variable (see PslDebug  Run-Time Error Checking Variable on page 6-2 for more information). PslDebug can be useful in debugging multiprocess lock interactions.
Failure of the lock Function
The lock() function can fail if a nonblocking request fails timeout is exceeded before the lock is granted
The lock() function can fail for an infinite timeout if a special-case upgrade request is granted the system has performed some external deadlock correction
Example
The following PSL statements use the lock() function to request a read lock. The process will wait up to three minutes to acquire the lock.
if (lock("PASSWD_FILE_LOCK","w",180)) { print("Got the lock\n"); } else { print("Did not get it\n"); }
lock()
4-171
log()
Enter and information event to the PATROL Event Manager
Format
log("message","severity")
Parameters
Parameter message severity Definition
text string to be recorded in the PATROL Event Manager Event Diary for an information event Optional text string that specifies the severity of the log message
Description
The log() function generates an Information Event and inserts message into its Event Diary. The event is recorded in PATROLs Event Log. If severity is specified, it is recorded as the severity of the event. The log() function always returns the NULL string. The log() function is provided for the purpose of backward compatibility with previous versions of PSL and should not be used to send messages to the Version 3.0 PATROL Event Manager. Use the event_trigger() function (see page 4-111) to send messages to the Version 3.0 PATROL Event Manager.
Example
The following is an example of the log() function:
log("Just Testing . . . ","This is not a real log message");
4-172
loge()
Return the natural logarithm of the argument
Format
loge(argument)
Parameter
Parameter argument Definition
Numeric value whose natural logarithm is to be determined. Valid range: argument > 0
Description
The loge() function returns the logarithm of argument with respect to the natural logarithm base e = 2.71828 . . . The output range for the loge() function is  < loge() < .
loge()
4-173
Example
The following loge() function calls print a number of useful physical and mathematical constants:
function main() { PI = 3.141593; printf("loge(PI) printf("loge(10) printf("loge( 2) printf("loge( 3) return; }
= = = =
4-174
log10()
Return the logarithm to base 10 of the argument
Format
log10(argument)
Parameter
Parameter argument Definition
Numeric value whose base 10 logarithm is to be determined. Valid range: argument > 0
Description
The log10() function returns the logarithm of argument with respect to base 10. The output range for the log10() function is  < log10() < .
log10()
4-175
Example
The following log10() function calls print a number of useful physical and mathematical constants:
function main() { PI = 3.141593; printf("log10(PI) printf("log10( e) printf("log10( 2) printf("log10( 3) return; }
= = = =
4-176
ntharg()
Return a formatted list containing fields from a text string
Format
ntharg("text","arguments","delimiters","separator")
Parameters
Parameter text Definition
Text to be separated into fields by the ntharg() function. The text can be a text string enclosed in double quotation marks, or one or more PSL commands that produce text as output. Integer list specifying the field numbers ntharg() should look for in each line of text. Fields are specified as follows: x,y x-y -x xfield x and field y all fields from x to y inclusive all fields from 1 to x inclusive all fields from x to the new-line character inclusive
arguments
delimiters
One or more optional characters that ntharg() should treat as field separators when examining text. Default if not specified: space and \t (tab) Optional character that should be placed between each field of ntharg() output Default if not specified: new-line character (\n)
separator
ntharg()
4-177
Description
The ntharg() function returns the arguments in text and normally interprets each line in text as a white space-separated (space or tab) list of fields. If delimiters is given, it specifies the list of characters that ntharg() should treat as field separators. The ntharg() function normally returns selected fields as a new-line delimited list. If separator is given, it specifies the delimiter to be placed between items in the returned list.
Note
The difference between the ntharg() function and the nthargf() function is as follows: The ntharg() function treats each delimiter that follows a non-delimiter character as the end of a field. The ntharg() function interprets two or more adjacent delimiters as a single delimiter, thereby ignoring multiple delimiters and treating them as one. The nthargf() function treats each delimiter as the end of a field. The nthargf() function interprets two or more adjacent delimiters as delimiting one or more NULL strings whose content can be requested and returned.
4-178
Examples
The following example prints the login name and home directory of each user listed in the Unix system password file.
foreach user (cat("/etc/passwd")) { print(ntharg(user,"1,6",":","\t"),"\n"); }
The following example illustrates the difference between the ntharg() function and the nthargf() function:
string = "abc::123:xyz"; A = ntharg(string,"3",":"); B = nthargf(string,"3",":"); print("ntharg() 3rd string argument is ",A,"\n"); print("nthargf() 3rd string argument is ",B,"\n");
ntharg()
4-179
nthargf()
Return a formatted string containing fields from a text string
Format
nthargf("text","arguments","delimiters","separator")
Parameters
Parameter text Definition
Text to be separated into fields by the nthargf() function. The text can be a text string enclosed in double quotation marks, or one or more PSL commands that produce text as output. Integer list specifying the field numbers nthargf() should look for in each line of text. Fields are specified as follows: x,y x-y -x xfield x and field y all fields from x to y inclusive all fields from 1 to x inclusive all fields from x to the new-line character inclusive
arguments
delimiters
One or more characters that nthargf() should treat as field separators when examining text. The nthargf() function treats each occurrence of
delimiters as delimiting a field. The nthargf() function interprets two or more adjacent delimiters as
delimiting one or more NULL fields. Default if not specified: space and \t (tab)
separator
Optional character that should be placed between each field of nthargf() output Default if not specified: new-line character (\n)
4-180
Description
The nthargf() function returns the arguments in text. The nthargf() function normally interprets each line in text as a white space-separated (space or tab) list of fields. If delimiters is given, it specifies the list of characters that nthargf() should treat as field separators. The nthargf() function normally returns selected fields as a new-line delimited list. If separator is given, it specifies the delimiter to be placed between items in the returned list.
Note
The difference between the nthargf() function and the ntharg() function is as follows: The nthargf() function treats each delimiter as the end of a field. The nthargf() function interprets two or more adjacent delimiters as delimiting one or more NULL strings whose content can be requested and returned. The ntharg() function treats each delimiter that follows a non-delimiter character as the end of a field. The ntharg() function interprets two or more adjacent delimiters as a single delimiter, thereby ignoring multiple delimiters and treating them as one.
nthargf()
4-181
Example
The following example illustrates the difference between the ntharg() function and the nthargf() function:
string = "abc::123:xyz"; A = ntharg(string,"3",":"); B = nthargf(string,"3",":"); print("ntharg() 3rd string argument is ",A,"\n"); print("nthargf() 3rd string argument is ",B,"\n");
4-182
nthline()
Return specified lines from a text string
Format
nthline("text","lines","separator")
Parameters
Parameter text Definition
Text to be separated into lines by the nthline() function. The text can be a text string enclosed in double quotation marks, or one or more PSL commands that produce text as output. Integer list specifying the line numbers nthline() should look for in text. Lines are specified as follows: x,y x-y -x xline x and line y all lines from x to y inclusive all lines from 1 to x inclusive all lines from x to EOF character inclusive
lines
separator
Optional character that should be placed between each field of nthline() output Default if not specified: new-line character (\n)
nthline()
4-183
Description
The nthline() function returns the lines of text separated by new-line characters. If you specify a separator, the nthline() function will use separator to separate lines.
Note
The difference between the nthlinef() and nthline() functions is as follows: The nthlinef() function treats each new-line character as a line. The nthline() function treats only a nonempty line (that is, a line with a nonnew-line character preceding a new-line character) as a line.
BMC Software recommends you use nthlinef() function to be consistent with other PSL functions.
Example
The following PSL script prints the top five processes executing on a Unix system.
# print the top five processes print(nthline(system("ps -eaf"),"2-6"));
The following example illustrates the difference between the nthline() function and the nthlinef() function:
string = "abc\n\n123\nxyz"; A = nthline(string,3); B = nthlinef(string,3); print("nthline() 3rd string argument is : ",A,"\n"); print("nthlinef() 3rd string argument is : ",B,"\n");
4-184
nthlinef()
Return specified lines from a text string
Format
nthlinef("text","lines","separator")
Parameters
Parameter text Definition
Text to be separated into lines by the nthlinef() function. The text can be a text string enclosed in double quotes, or one or more PSL commands that produce text as output. Integer list specifying the line numbers nthlinef() should look for in text. Lines are specified as follows: x,y x-y -x xline x and line y all lines from x to y inclusive all lines from 1 to x inclusive all lines from x to EOF character inclusive
lines
separator
Optional character that should be placed between each field of nthlinef() output Default if not specified: new-line character (\n)
nthlinef()
4-185
Description
The nthlinef() function returns the lines of text separated by new-line characters. If you specify a separator, the nthlinef() function will use separator to separate lines.
Note
The difference between the nthlinef() and nthline() functions is as follows: The nthlinef() function treats each new-line character as a line. The nthline() function treats only a nonempty line (that is, a line with a nonnew-line character preceding a new-line character) as a line.
BMC Software recommends you use nthlinef() function to be consistent with other PSL functions.
Example
The following PSL script prints the top five processes executing on a Unix system.
# print the top five processes print(nthlinef(system("ps -eaf"),"2-6"));
The following example illustrates the difference between the nthlinef() function and the nthline() function:
string = "abc\n\n123\nxyz"; A = nthline(string,3); B = nthlinef(string,3); print("nthline() 3rd string argument is : ",A,"\n"); print("nthlinef() 3rd string argument is : ",B,"\n");
4-186
num_consoles()
Return the number of consoles registered to the PATROL Agent or that use the PSL script
Format
num_consoles(ALL)
Parameter
Parameter
ALL
Definition
Optional flag that returns the number of consoles registered with the PATROL Agent. If the flag is omitted, the num_consoles() function returns the number of PATROL Consoles that use this PSL script.
Description
The num_consoles() function returns a integer representing the number of PATROL Consoles that:   are registered with the PATROL Agent (ALL argument) use the script in which the num_consoles() function appears (no argument)
The value that the num_consoles() function returns when ALL is omitted can be any positive integer from 0 to the number obtained from the num_consoles(ALL) function, that is, the total number of consoles registered with the PATROL Agent. The num_consoles() function (no ALL argument) always returns 1 when the PSL script is used as a menu command.
num_consoles()
4-187
Example
The following example uses the num_consoles() function to return the number of consoles connected to the PATROL Agent, and the number of consoles connected to the PATROL Agent that are running the example script.
connect = num_consoles(ALL); scriptrunner = num_consoles(); print("Number of Consoles connected to this Agent : ",connect,"\n"); print("Number of Consoles executing this script : ",scriptrunner,"\n");
4-188
pconfig()
Manage the PATROL Agent configuration variables
Syntax
pconfig("APPEND","variable","value") pconfig("DELETE","variable","value") pconfig("FORMAT",options,"name_separator", "value_separator","variable"); pconfig("GET","variable") pconfig("LIST") pconfig("MERGE","variable","value") pconfig("PURGE") pconfig("RELOAD") pconfig("REPLACE","variable","value");
Parameters
Parameter variable Definition
REQUIRED string identifying the PATROL Agent configuration variable on which pconfig() is to act. The variable parameter is validated using the following rules:  variable is composed of name segments separated by a slash (/)  variable may start with a slash (/), but not end with a slash(/)  variable may not contain empty segments  variable may not contain unprintable characters  variable may not contain whitespace other than the space character  variable may contain spaces within a segment but not at the beginning or end of a segment
pconfig()
4-189
Parameter value
Definition
Optional string identifying the value associated with variable. If omitted, the default value is the NULL string. You can assign multiple values using a comma to separate values in the string as follows: "value1,value2, . . . ,valuen"
options
Optional bitmask of preferences that specifies the variables to be returned and how they are to be formatted Optional string to output after the name of variable Optional string to output after the value of variable
name_separator value_separator
Description
The pconfig() function can be used to view and change the configuration variables for a PATROL Agent. Changes made with the pconfig() function take effect immediately without restarting the PATROL Agent, and these changes are persistent and will survive a PATROL Agent restart. The following topics describe each of the pconfig() options. (See the PATROL Agent Reference Manual for more information about PATROL Agent configuration.)
The APPEND Option
The pconfig("APPEND") function appends value to the list of values for variable. If variable does not exist, the pconfig("APPEND") function creates variable and adds value to it. The pconfig("APPEND") function does not check to see if variable already has value in its list of values. (If so, the pconfig("APPEND") function adds it a second time.)
4-190
The pconfig("APPEND") function returns the NULL string and sets the PSL variable errno = 0 (E_PSL_NO_ERROR) if successful or a PSL error message string and nonzero errno return value otherwise. (See pconfig() Function Messages and Return Codes on page 4-196.)
The DELETE Option
The pconfig("DELETE") option deletes variable information from the PATROL Agent configuration: If both variable and value are specified, the pconfig("DELETE") function deletes value from variable If only variable is specified, the pconfig("DELETE") function deletes variable from the PATROL Agent configuration.
If variable does not exist in the PATROL Agent configuration, the pconfig("DELETE") function performs no operation. The pconfig("DELETE") function returns the NULL string and sets the PSL variable errno = 0 (E_PSL_NO_ERROR) if successful, or a PSL error message string and nonzero errno return value otherwise. (See pconfig() Function Messages and Return Codes on page 4-196.)
The FORMAT Option
The pconfig("FORMAT") returns a list of PATROL Agent configuration variables or a single configuration variable in the format that you specify. The pconfig("FORMAT") call is similar to pconfig("GET") and pconfig("LIST") calls, but it can be a little more flexible in some situations. The options parameter is a bitmask of preferences that specifies the variables to be returned and how they are to be formatted. The available option preferences areas follows: 64 32 16 8 Place quotes around name and values Search for given variable only Output default variables Output overridden/non-default variables
pconfig() 4-191
4 2 1
Combinations of these preferences can be specified by ORing the values together. For example, if options is set to 18 (that is, 16 | 2), then the pconfig("FORMAT") option returns the current values of the default variables. The name_separator and value_separator parameters specify the strings that should appear after each variable name and each value respectively. The last parameter variable specifies the name of the variable that should be returned. Without variable, pconfig("FORMAT") is a generalized form of pconfig("LIST") but with a specified variable. The following lists the parameters that are optional along with their default values:
options name_separator value_separator variable
If the pconfig("FORMAT") function cannot obtain the list of variables or the value of a variable, it returns a PSL error message string and a nonzero errno return value. (See pconfig() Function Messages and Return Codes on page 4-196.)
Examples of the pconfig("FORMAT") Option
# Get just the current value pconfig("FORMAT",32|2,"","", "/AgentSetup/historyRetentionPeriod");
4-192
The pconfig("GET") function returns the default and current values of variable in a PSL list with the following format:
default_value\n current_value
If the pconfig("GET") function cannot obtain the values of variable, it returns a PSL error message string and a nonzero errno return value.
The LIST Option
The pconfig("LIST") function returns a list of all the PATROL Agent configuration variables in a PSL list with the following format:
variable1\n variable2\n ... variablen
If the pconfig("LIST") function cannot obtain the list of variables, it returns a PSL error message string and a nonzero errno return value.
The MERGE Option
The pconfig("MERGE") function merges value into the list of values for variable. If variable does not exist, the pconfig("MERGE") function creates variable and adds value to it. The pconfig("MERGE") function checks to see if variable already has value in its list of values and, if so, performs no action. The pconfig("MERGE") function returns the NULL string and sets the PSL variable errno = 0 (E_PSL_NO_ERROR) if successful or a PSL error message string and nonzero errno return value otherwise. (See pconfig() Function Messages and Return Codes on page 4-196.)
pconfig()
4-193
The pconfig("PURGE") function removes the existing configuration from the PATROL Agent and creates a new one based on the PATROL Agent config.default file. The pconfig("PURGE") function returns the NULL string and sets the PSL variable errno = 0 (E_PSL_NO_ERROR) if successful or a PSL error message string and nonzero errno return value otherwise. (See pconfig() Function Messages and Return Codes on page 4-196.)
The RELOAD Option
The pconfig("RELOAD") function reloads the default configuration information from the PATROL Agent config.default file only if the timestamp on config.default has been updated since the last time it was read by the PATROL Agent. (The PATROL Agent keeps the timestamp of the last config.default file it read in the configuration database files.) The pconfig("RELOAD") function will not modify any user-created variables or values, but will replace any default variables and values that are different than those in config.default. The pconfig("RELOAD") function returns the NULL string and sets the PSL variable errno = 0 (E_PSL_NO_ERROR) if successful or a PSL error message string and nonzero errno return value otherwise. (See pconfig() Function Messages and Return Codes on page 4-196.)
4-194
The pconfig("REPLACE") function replaces all existing values of variable with value: If variable does not exist, the pconfig("REPLACE") function creates variable and adds value to it If variable exists and has no values, the pconfig("REPLACE") function adds value to variable If value is already in the list of values for variable, the pconfig("REPLACE") function deletes all other values so that only value remains.
The pconfig("REPLACE") function returns the NULL string and sets the PSL variable errno = 0 (E_PSL_NO_ERROR) if successful or a PSL error message string and nonzero errno return value otherwise. (See pconfig() Function Messages and Return Codes on page 4-196)
pconfig()
4-195
Message
E_PSL_NO_ERROR E_PSL_BAD_FUNCTION_PARAMETER
117 118
E_PSL_ACL_FAILED E_PSL_CONFIG_FAILED
The pconfig() function returns this text string to indicate that it was unable to write to the PATROL Agent configuration file because of Access Control List (ACL) restrictions. That is, the account under which the pconfig() command executed does not have permission to write to the PATROL Agent configuration file. When the pconfig() function returns this message it sets the PSL variable errno = 117 (E_PSL_ACL_FAILED). The pconfig() function can return this message for the APPEND, DELETE, MERGE, PURGE, RELOAD, and REPLACE options.
4-196
The pconfig() function returns this text string to indicate that it was unable to purge the PATROL Agent configuration file. (Either it could not remove the existing file, or it could not create the new file from the config.default file). When the pconfig() function returns this message it sets the PSL variable errno = 118 (E_PSL_PCONFIG_FAILED). The pconfig() function can return this message for the PURGE option.
Configuration: Database RELOAD failed
The pconfig() function returns this text string to indicate that it was unable to reload the PATROL Agent configuration file default values from the config.default file. (This can be a config.default file problem or a problem reading the configuration database files.) When the pconfig() function returns this message it sets the PSL variable errno = 118 (E_PSL_PCONFIG_FAILED). The pconfig() function can return this message for the RELOAD option.
NULL String
The pconfig() function returns the NULL string to indicate it successfully completed the operation. When the pconfig() function returns this message it sets the PSL variable errno = 0 (E_PSL_NO_ERROR). The pconfig() function returns this message for the APPEND, DELETE, MERGE, PURGE, RELOAD, and REPLACE options.
Syntax Error: pconfig argument 1 missing
The pconfig() function returns this text string to indicate that no option (APPEND, DELETE, FORMAT, MERGE, and so on) was specified. When the pconfig() function returns this message it sets the PSL variable errno = 118 (E_PSL_PCONFIG_FAILED).
pconfig()
4-197
The pconfig() function returns this text string to indicate that the specified option was not one of APPEND, DELETE, FORMAT, GET, LIST, MERGE, PURGE, RELOAD, or REPLACE. When the pconfig() function returns this message it sets the PSL variable errno = 96 (E_PSL_BAD_FUNCTION_PARAMETER).
Syntax Error: pconfig argument 2 missing
The pconfig() function returns this text string to indicate that its option requires variable and variable was not specified. (The value is always optional and always defaults to the NULL string when omitted.) When the pconfig() function returns this message, it sets the PSL variable errno = 96 (E_PSL_BAD_FUNCTION_PARAMETER). The pconfig() function can return this message for the APPEND, DELETE, GET, MERGE, and REPLACE options.
Syntax Error: pconfig argument 2 is not a valid variable name
The pconfig() function returns this text string to indicate that the variable parameter has an invalid syntax. When the pconfig() function returns this message, it sets the PSL variable errno = 96 (E_PSL_BAD_FUNCTION_PARAMETER). The pconfig() function can return this message for the APPEND, DELETE, GET, MERGE, and REPLACE options.
Syntax Error: pconfig argument 5 is not a valid variable name
The pconfig() function returns this text string to indicate that the variable parameter has an invalid syntax. When the pconfig() function returns this message, it sets the PSL variable errno = 96 (E_PSL_BAD_FUNCTION_PARAMETER). The pconfig() function can return this message for the FORMAT option.
4-198
Example
The following PSL scripts contain examples of the pconfig() function:
The pconfig() Function Options
The following PSL script contains examples of the pconfig() function and its different options:
# Get the value for a configuration variable function InetVarGet( app, inst, var ) { local varpath; varpath = "/InetSetup/" . app . "/" . inst . "." . var; # Looking up the (non-default) configuration vars return( nthlinef(pconfig("GET", varpath), 2, "") ); } # Set the value of a configuration variable function InetVarSet( app, inst, var, val ) { local varpath; varpath = "/InetSetup/" . app . "/" . inst . "." . var; return( pconfig("REPLACE", varpath, val) ); } # Delete a configuration variable function InetVarDelete( var ) { return( pconfig("DELETE", var) ); } # Get a list of configuration variables function InetVarList( expr ) { local tlist, all_list; all_list = pconfig("LIST"); tlist = grep("^/InetSetup/", all_list); if (expr) { tlist = grep( expr, tlist); } return( sort( tlist ) ); }
pconfig()
4-199
The following script uses the pconfig() function as part of the PSL script for a Make Current KMs Preloaded menu command:
#make_preloaded_km_list.psl # # # History: requires response_def_lib; requires unix_misc_lib; response_def(); from = get_console_info(); if(console_type() != 1) { error_popup("Only a Developer Console can set preloaded KMs"); event_trigger("0", "41", "INFORMATION", 9, "Attempt to set preloadedKMs by ".from); exit; } buf = system("%DUMP KM_LIST"); buf = nthlinef(buf,"4-".(int(lines(buf)) - 1)); kms = ""; foreach lin (buf){ kms = kms . ntharg(lin, 2) . ".km=1\n"; } kms = sort(kms); resp_ret = response("Make Current KMs Preloaded",-1,"h=430,w=395", LABEL."Select KMs to preload (default: all)", SEP_HORIZ, LIST_MULTIPLE.kms, RADIO_HORIZ."Merge into preload list=1\nOnly preload these=0\n" ); act = trim(nthlinef(resp_ret,1), "\n"); if(act){ sel_list = trim(nthlinef(resp_ret,2), "\n"); merge_rep = trim(nthlinef(resp_ret,3), "\n"); work = ""; foreach word sel_num (sel_list) { work = work . nthargf(nthlinef(kms, sel_num), 1, "=") . "\n"; } maxlen = get("/maxConfigValLen"); if(length(kms) > maxlen){ error_popup("KM list too long, cannot quick-set"); exit; } if(merge_rep == 1){ method = "MERGE"; yn = rusure("Merge these into preloaded KM list?\n\n".work); } else { method = "REPLACE"; yn = rusure("Set preloaded KM list to:\n\n".work); } if(yn == 1){ kms = ntharg(work, "1-", "\n", ","); event_trigger("0", "41", "INFORMATION", 9, "/AgentSetup/preloadedKMs changed by ".from); pconfig(method, "/AgentSetup/preloadedKMs", kms); } }
4-200
popen()
Open a PSL channel to a process
Format
popen("type","command","instance","username","password")
Parameters
Parameter type Definition
Command processor that interprets and executes
command
Valid range: The built-in command types OS or PSL, or a valid user-defined command type
command instance
Syntax of the submitted command Optional application instance against which command executes Default: The application instance that is the nearest ancestor of command
username
Optional user name under which the process channel is opened Default: The user name under which the popen() function is called
password
Optional password under which the process channel is opened Default: The password under which the popen() function is called
Description
The popen() function spawns a process to execute a command of a defined type and returns a channel number which can then be used to read the commands output or write messages to the command. (Refer to the PSL read() and write() functions on pages 4-222 and 4-415 respectively.) The popen() function returns 1 on error.
BMC Software, Inc., Confidential and Proprietary Information
popen()
4-201
The popen() function can be used to submit a command to run in the background. Sometimes a long running process like a daemon may be better run in the background, but care should be taken when submitting commands in the background. Normally, when a command is executed by a parameter, or as a recovery action, it is executed in the foreground, and the parameter waits for the command script to finish before refreshing. This ensures that the recovery action is complete before the parameter is checked to see if an additional recovery action is required. However, if a recovery action is submitted in the background, the command script can finish before the recovery action is complete. When the command script finishes, the parameter refreshes. If the parameter is still in an alarm state, a second recovery action may start and conflict with the first recovery action.
Example
The following PSL script uses the popen() function to open a process channel to the Unix shell command interpreter and then uses the write() function to submit a script to the command interpreter.
chan = popen("OS","/bin/sh"); if chan(chan_exists(chan)) { write(chan,"/usr/local/myscript &"); close(chan); }
4-202
popup_report()
Pop up a task window on interested Consoles
Format
popup_report("title","application","handle","data")
Parameters
Parameter title application Definition
The title that should appear on the task window Optional name of the application from which to determine which Consoles to pop up the task window on Optional task ID returned by a previous call to popup_report() Optional initial data to be displayed in the task window
handle data
Description
The popup_report() function pops up a task window on all consoles that are interested in the specified application. If application is the empty string, "", then the task window pops up on those consoles interested only in the PSL process that is making the call to the popup_report() function. The handle becomes invalid if all consoles have destroyed the task window thereby removing all the status information about the task.
popup_report()
4-203
If handle is not the empty string, the following actions occur: If the report exists (that is, the task window has been popped up previously), then the task window pops up only on those consoles that have started monitoring the application/process since the last call to the popup_report() function. The data does not necessarily go to all of the consoles that are interested in the task because the consoles that were previously popped up already have the data.
The popup_report() function returns one of the following values:   the task id (that is, handle) if the function call is successful the empty string, "", if the function call fails (that is, if an invalid handle is used)
Note
The popup_report() and write_to_report() functions use handle to identify the report to be popped up or written to, respectively. To write text to the popped-up task window, see the write_to_report() function on page 4-417.
4-204
Examples
The two following examples demonstrate how to pop up a task window on interested Consoles. Both examples call the write_to_report() function to write text to the popped-up windows. (See page 4-417 for more information on the write_to_report() function.)
Simple Example
# Pop up a report on all connected Consoles handle = popup_report("File System Report"); if (handle) { write_to_report(handle,system("/bin/df")); }
Complex Example
# Pop up a report on all Consoles that are currently monitoring the # FILESYSTEM application. And refresh the report every 10 seconds and ensure # that new Consoles can also see the report. handle = popup_report("File System Report","FILESYSTEM","", "Started at ".date()."\n"); while (handle) { sleep(10); # Pop up a report on all consoles that started monitoring the # FILESYSTEM application after the popup_report() function was called handle = popup_report("File System Report (already running)", "FILESYSTEM",handle,"You missed the start\n"); write_report(handle,system("/bin/df")); }
popup_report()
4-205
pow()
Raise a number to a power
Format
pow(base,exponent)
Parameters
Parameter base exponent Definition
Numeric value that is to multiplied by itself exponent number of times Numeric value that indicates the number of times base should be multiplied by itself
exponent must be positive if base = 0, and exponent must be an integer if base < 0.
Description
The pow() function returns the value of base raised to the power exponent, or baseexponent. The output range for the pow() function is  < pow() < .
4-206
Example
The following PSL script uses the pow() function to produce a table of powers of the integers from one to nine.
function main() { print(" n n^4 n^5 n^6 print("-- --------- --------- --------base = 1; while (base <= 9) { printf("%2d",base); exponent = 4; while (exponent <= 9) { printf(" %9d",pow(base,exponent)); exponent++; } printf("\n"); base++; } } n^7 --------n^8 --------n^9\n"); ---------\n");
pow()
4-207
print()
Print text to a computer output window on the PATROL Console
Format
print("text1",...,"textn")
Parameter
Parameter text1 . . . textn Definition
One or more text strings or variables containing a text string to be output by the print() function
Description
The print() function prints text1 . . . textn to the computer system window on the PATROL Console. If the PSL script is a task, the output of the print() function is directed to the tasks own window. The print() function always returns the NULL string.
Example
Each of the following print() functions displays the phrase Hello World! to the computer system window on the PATROL Console.
print ("Hello ","world!","\n"); print("Hello world!\n"); print("Hello "); print("world!"); print("\n");
4-208
printf()
Print text formatted to the C library printf() routine specification
Format
printf(format)
Parameter
Parameter format Definition
Text, variable names, and control characters that specify the content and format of output to the computer or task output window.
printf()
4-209
Parameter format
(continued)
Description
The printf() function displays output to the computer or task output window using formatting similar to the standard C printf() function. A bad format or one that is valid for the C language but not for the printf() function results in a PSL run-time error that sets the PSL errno variable. The printf() function return value is always the null string.
C Conventions Not Supported by the PSL printf Function
The printf() function does not support the C convention of using the asterisk (*) as a field width or precision indicator. The printf() function does not support the %p and %n conversion characters. The length modifiers h, l (ell), and L are not valid and are ignored by the printf function. The printf() function format conversions are passed directly to the C library printf() routine on each platform. The output for obscure formatting features may differ across platforms, especially on platforms with libraries that do not conform to ANSI C requirements.
BMC Software, Inc., Confidential and Proprietary Information
4-210
Conversion Differences between the C printf Routine and PSL printf Function
The format conversions have the same meaning between standard C and PSL, but the concept of variable types differs between the two. PSL supports only string types for its variables, and thus string arguments to the printf() function are converted in a manner appropriate for the format conversion:   Integral formats such as %d convert the string to signed integers. Noninteger numeric formats such as %f convert to floating point values.
%c prints the ASCII equivalent of its integer argument or for
nonnumeric arguments the first character of its argument. (Applying %c to 65 will print A and to AB will print A.)  
%s causes no conversion. %% requires no argument.
The printf() function provides one nonstandard C extensionthe %N conversion. The %N conversion preprocesses a numeric string so that commas separate each group of three digits beginning at the right side of the string. For example, the %N conversion causes the following conversions: 1234 1,234 12345 12,345 123456 123,456 The %N conversions ignores initial minus signs and blanks while searching for the first sequence of digits so that %N can be applied to negative values. If no digits are found after the skipped characters, the printed argument is unchanged.
printf()
4-211
The %N conversion only modifies the first sequence of digits. For example, the %N conversion changes floating point numbers like 1234.1234 to become 1,234.1234 without changing to the digit sequence to the right of the decimal point. As part of the %N conversion, the printf() function performs a %s conversion using the field width and precision specifiers supplied in format. The printf() function prints the string resulting from the combined %N and %s conversions. Because of the embedded %s conversion, field width and precision under %N conversion have the same effect as with %s.
Note
Currently, no localization is supported by %N, and so the formatting achieved by %N does not change in different locales.
Example
The following series of printf() function calls illustrate several formatting characters used for numbers and strings:
string = "1257384.00234600000"; printf(" string as an integer : %d\n",string); printf(" string as a formatted integer : %7N\n",int(string)); printf(" string as a real : %f\n",string); printf(" string as a formatted real : %12.4f\n",string); printf(" string as a character string : %s\n",string); printf(" string in scientific notation : %e\n",string);
4-212
proc_exists()
Verify that a process exists
Format
proc_exists(pid)
Parameter
Parameter pid Definition
Process identifier number of the process whose existence is being verified
Description
The proc_exists() function returns TRUE if the process with process identifier pid exists; FALSE if it does not.
Example
The following example uses the proc_exists() function to verify that a process with a specific process ID exists:
if (proc_exists(1)) { print("A process with PID 1 is running\n"); }
proc_exists()
4-213
process()
Return a list of processes from the PATROL Agent process cache
Format
process("regular-expression")
Parameter
Parameter regular-expression Definition
Character sequence that defines the pattern the process() function searches for in the PATROL Agent process cache.The regular-expression conforms to the regular expressions defined in the Unix ed(1) command description and the Unix regexp(5) description. Following is a brief summary of several regular expression characters: ^ $ . * [] [^] beginning of line end of line match any single character match zero or more repetitions of the preceding match any of the characters contained within match any characters except those contained within
Description
The process() function returns the list of processes from the name and cmd columns in the PatrolAgents process cache that match the regular expression regular-expression.
4-214
Process core image size (in blocks) Integer number of CPU seconds consumed by the process First word of the command line that started the process Complete command line that started the process. Note that the command line may have been modified during process execution.
Note
Some platforms do not support all the return values. For a specific platform, the process() function generally returns the same information as the ps command (patrolps command for OS/2). The process() function returns the NULL string if no processes match regular-expression. The process() function returns a question mark (?) for any values that cannot be determined.
process()
4-215
Example
The following PSL commands lists all active processes:
# find all processes procs = process(""); print (procs);
4-216
PslExecute()
Start a PSL process
Format
PslExecute("name","PslScript",errorlist,warninglist)
Parameters
Parameter name PslScript errorlist Definition
Text string that provides a descriptive identifier for the new PSL process. Text string containing the PSL commands that should be executed. Optional variable to which the PSL interpreter/compiler will return text string error messages created while compiling PslScript. Default if not specified: the PslExecute() function does not return compilation error messages.
warninglist
Optional variable to which the PSL interpreter/compiler will return text string warning messages generated while compiling PslScript. Default is not specified: the PslExecute() function does not return compilation warning messages.
Description
The PslExecute() function compiles and executes the statements in PslScript and runs them in the PATROL Agent as the PSL script name. If errorlist and warninglist are specified, the PSL interpreter/compiler will return any error or warning messages that it generates to those variables.
PslExecute()
4-217
The PslExecute() function returns: 0 if name has been successfully created and is executing 1 if name experienced a compilation errors 2 if name experienced a process creation error
Example
The following example uses the PslExecute() function to create the PSL process called myscript to print the message Hello world!
PslExecute("myscript","print(\"Hello world!\\n\");",errors,warnings); printf("compilation errors for myscript :\n%s\n",errors); printf("compilation warnings for myscript :\n%s\n",warnings);
4-218
PslSetOptions()
Set the run-time options for the calling PSL process to the specified value
Format
PslSetOptions(options)
Parameters
Parameter options Definition
Optional. Available options are 0 1 2 No options Calculate the message digest Send the current PSL source line in each XPC call
These options can be selected together. For example, 1|2 = 3 selects both 1 and 2.
Description
Use the PslSetOptions() function to set the run-time options for the calling PSL process to the specified value. The current value of the options mask is always returned. If no argument is given, then the process options are not changed; this is useful if you just want to retrieve the current options mask. This function is useful only if the PSL program uses the XPC (external PSL call) server.
Example
The following is an example of the PslSetOptions() function:
current_options = PslSetOptions(2);
PslSetOptions()
4-219
random()
Return a random number
Format
random(maximum)
Parameter
Parameter maximum Definition
Optional upper bound for the values returned by random: 0  random()  maximum  1 Valid range: maximum > 0 Default if not specified: maximum = 232  1 (from the underlying C function)
Description
The random() function is equivalent to the standard C library random() function. If maximum is zero or negative, the random() function will return a run-time error message.
4-220
Example
The following PSL statements test the random() function by simulating the rolling of a single six-sided die. If the die (and the random() function) are honest, each of the numbers is equally likely and after an arbitrarily large number of throws will come up an approximately equal number of times.
function main() { srandom(time()); # seed random() with the system clock ones = twos = threes = fours = fives = sixes = 0; limit = 6000; count = 0; while (count++ <= limit) { roll = int(random(6)) + 1; switch (roll) { case 1: {ones++;} case 2: {twos++;} case 3: {threes++;} case 4: {fours++;} case 5: {fives++;} case 6: {sixes++;} } } expected = int(limit / 6); print(" expected actual\n"); print(" ---------------\n"); printf("%2d %8d %8d\n",1,expected,ones); printf("%2d %8d %8d\n",2,expected,twos); printf("%2d %8d %8d\n",3,expected,threes); printf("%2d %8d %8d\n",4,expected,fours); printf("%2d %8d %8d\n",5,expected,fives); printf("%2d %8d %8d\n",6,expected,sixes); }
1 2 3 4 5 6
random()
4-221
read()
Read from a PSL file or process channel
Format
read(channel,size)
Parameters
Parameter channel size Definition
The process I/O channel number from which the read() function reads data Optional integer value controlling the amount of data that the read() function reads from channel Valid range:  size = 0 instructs the read() function to return as soon as it has read something from the channel  size = 1 instructs the read() function to read all data available by either reading until the end of file on a channel opened with the fopen() function or by blocking until the child process completes for a channel opened with the popen() function  size = n, where n > 0, instructs the read() function to perform a non-blocking read of size bytes and return control immediately. If no text is available, the empty string is returned and the errno variable is not set. The non-blocking mode only applies to channels opened by popen()it is ignored without error for channels opened by fopen(). Default if not specified: size = 0
Description
The read() function returns the data it reads one byte at a time from channel. The read() function returns the value EOF (that is, the NULL string) on an end-of-file or error condition.
BMC Software, Inc., Confidential and Proprietary Information
4-222
Channels are created by calling the fopen() or popen() function. (For more information about the fopen() function, see page 4-126. For more information about the popen() function, see page 4-201.)
Note
The read() function can block for a process channel created using the popen() function but not for a file channel created using the fopen() function. To enforce serialization for shared channels, no two reader processes (that is, read() or readln() functions) can be blocked on the same channel. The second reader process that attempts to block on the shared channel will fail, returning the NULL string and setting the PSL variable errno to E_PSL_BUSY_CHANNEL. Another possible shared channel failure can be caused by a close() function being executed against a channel that also has a blocked reader process. The close() function will cause the reader process to return the NULL string and set errno to E_PSL_UNBLOCKED_BY_CLOSE.
Example
The following PSL example opens a channel to the Unix operating system, executes a Unix ls command, then reads and prints the directory entries returned by the ls command.
chan = popen ("OS", "ls"); while ((data = read (chan,1)) ! = EOF) { print (data); } close (chan);
read()
4-223
readln()
Read a line of data from a PSL file or process channel
Format
readln(channel)
Parameter
Parameter channel Definition
The process I/O channel number from which the readln function is to read data
Description
The readln() function reads the next line of data from channel and returns it. The readln() function returns the value EOF (NULL) on end-of-file or error and sets errno = 55 (E_PSL_READ_FAILED) on end-of-file. Channels are created by calling the fopen() or popen() function. (Refer to the fopen() or popen() functions on pages 4-126 and 4-201 respectively.)
Note
The readln() function can block for a pipe channel created using the popen() function but not for a file channel created using the fopen() function. To enforce serialization for shared channels, no two reader processes (that is, read() or readln() functions) can be blocked on the same channel. The second reader process that attempts to block on the shared channel will fail, returning the NULL string and setting the PSL variable errno to E_PSL_BUSY_CHANNEL.
BMC Software, Inc., Confidential and Proprietary Information
4-224
Another possible shared channel failure can be caused by a close() function being executed against a channel that also has a blocked reader process.The close() function will cause the reader process to return the NULL string and set errno to E_PSL_UNBLOCKED_BY_CLOSE.
Limitation
The readln() function has a line limitation of 4K when executed against files opened with the fopen() function. The readln() function may truncate lines longer than 4K. This limitation does not apply to channels opened using the popen() function.
Example
The following is an example of the readln() function illustrating how to read lines of text from a file or process channel:
chan=fopen("/usr/users/passwd.dat","r"); if (chan_exists(chan)) { data=readln(chan); while ( errno != 55) { printf("%s\n",data); data=readln(chan); } close(chan); }
readln()
4-225
refresh_parameters()
Refresh PATROL parameters
Format
refresh_parameters("object","GLOBAL")
Parameters
Parameter object
GLOBAL
Definition
Name of the PATROL object that is to be updated. Mnemonic that instructs the refresh_parameters() function to update all instances of object if object is a global parameter.
Description
The refresh_parameters() function runs the PATROL parameters identified by object:  If object is a computer or application instance, run all parameters that belong to object If object is a local parameter, run the parameter for object If object is a global parameter and "GLOBAL" is specified, run all instances of the global parameter object If object is a global parameter and "GLOBAL" is not specified, run only the named instance of object
To properly refresh a consumer parameter, you must also refresh its collector parameter.
4-226
Examples
The following refresh_parameters() function refreshes the PAUserErrors parameter for the instance PATROLAGENT:
refresh_parameters("/PATROLAGENT/PATROLAGENT/PAUserErrors");
The following refresh_parameters() function refreshes all parameters for the instance PATROLAGENT:
refresh_parameters("/PATROLAGENT/PATROLAGENT");
refresh_parameters()
4-227
remote_close()
Close a session with a remote PATROL Agent
Format
remote_close(sessionID)
Parameter
Parameter sessionID Definition
The identifier of the PATROL Agent session that is to be closed. The sessionID is returned by the remote_open() function when you open a remote PATROL Agent session.
Description
The remote_close() function closes the connection to the remote PATROL Agent that is identified by sessionID. The remote_close() returns 1 if it successfully closes the remote session, and 0 otherwise. See remote_open() on page 4-242 for more information on using the remote functions.
Example
The following is an example of the remote_close() function.
if (remote_close(session) != 1) { # call user-written error handling routine CloseRemoteFailure(); }
4-228
remote_event_query()
Return a list of events in the PATROL Event Manager (PEM) repository of a remote PATROL Agent that match specified filter criteria
Format
remote_event_query(sessionID,"maxcount","timeout", "delimiter","format","start-time","stop-time","status","type", "node","origin","pattern","IDrange","class","severity")
Parameters
Parameter sessionID Definition
The identifier of the remote PATROL Agent session to which the remote event query is directed. The sessionID is returned by the remote_open() function when you open a remote PATROL Agent session. String that is the maximum number of events that will be returned in the event query. Specifying the NULL string "" causes maxcount to default to 100 String that is the maximum time in minutes that the session is willing to wait for the results of the remote event query. String that is used to separate each event in the list of events returned by the remote event query. Valid range:  "" indicating that a newline character \n will separate the entries  any valid characters including PSL string literals (see PSL String Literals on page 2-6).
maxcount
timeout
delimiter
remote_event_query()
4-229
Parameter format
Definition
Format string used to present each event entry. See Specifying the event_query() Output Format on page 4-91 Default: "" is equivalent to the string "%s %s %s %s %s %s %s %s\n" where the eight strings returned are (in order):         event ID assigned by the PEM event status event type event timestamp host name that produced the event application class or instance that produced the event text string from the event description field text string from the event diary field
Filter:
start-time
Time endpoint that specifies the oldest event timestamp that is valid for the remote event query. Valid range is "" indicating January 1, 1970 at 00:00:00 or one of the following strings:     PSL backward compatible: MMddhhmmyy RFC-822: day, date month year hh:mm:ss Unix: day month date hh:mm:ss year PSL date(): day month date hh:mm:ss year
day  Sun Mon Tue Wed Thu Fri Sat MM  01 to 12 month  Jan Feb Mar Apr May Jun Jul Aug Sep Oct
Nov Dec
dd or date 01 to 31 hh 00 to 23 mm and ss 00 to 59 year 1902 to 2037 yy 00 to 99. In the PSL compatibility format the current year is used when yy is omitted.
4-230
Parameter stop-time
Definition
Time endpoint that specifies the most recent event timestamp that is valid for the remote event query. Valid range is "" indicating all event timestamps in the repository or one of the following strings:     PSL backward compatible: MMddhhmmyy RFC-822: day, date month year hh:mm:ss Unix: day month date hh:mm:ss year PSL date(): day month date hh:mm:ss year
day  Sun Mon Tue Wed Thu Fri Sat MM  01 to 12 month  Jan Feb Mar Apr May Jun Jul Aug Sep Oct
Nov Dec
dd or date  01 to 31 hh  00 to 23 mm and ss  00 to 59 year  1902 to 2037 yy  00 to 99. In the PSL compatibility format the current year is used when yy is omitted. status
Event status that is valid for the remote event query. Valid range: O A C E D OPEN ACKNOWLEDGED CLOSED ESCALATED DELETED
For example: "O,A,C,D" matches all statuses except ESCALATED "O,A,C,E,D" or "" matches all statuses "O,C" matches only statuses OPEN and CLOSED
remote_event_query()
4-231
Parameter type
Definition
Event type that is valid for the remote event query. Valid range: I S E W A R INFORMATION CHANGE_STATUS ERROR WARNING ALARM RESPONSE
For example: "S,E,W,A,R" matches all event types except INFORMATION "I,S,E,W,A,R" or "" matches all event types "W,A" matches only event types WARNING and ALARM
node
Computer system name that is valid for the remote event query. Valid range is "" indicating all computer systems listed in the PEM repository or a host name character string. Application instance or class name that is valid for the remote event query. Valid range is "" for all application classes or a character string indicating a specific application instance or class. Character string within the event description field that is valid for the remote event query. Valid range is "" indicating any characters or a character string. String that defines the range of PATROL event IDs that are valid for the remote event query. Valid range: x x/y -/y x/-/event ID x event IDs between and including x and y event IDs less than and including y event IDs greater than and including x all events
origin
pattern
IDrange
class
Event class that is valid for the remote event query. Valid range is "" indicating all event classes or a character string specifying a specific event class.
4-232
Parameter severity
Definition
String containing the integer event severity that is valid for the remote event query. Valid range is "" for all event severities or an integer from 1  5 (5 being most severe) indicating a minimum severity.
Description
The remote_event_query() function returns a list of up to maxcount events found in the remote PATROL Agent Event Manager repository that match the filter criteria. The session to the remote PATROL Agent is identified by sessionID. The returned events are formatted as specified by format. The remote_event_query() function returns the NULL string if no events were found in the event repository that match the filter criteria.
remote_event_query()
4-233
Example
The following is an example of the remote_event_query() function.
print( "The result of the remote query\n", remote_event_query( mysession, # session handle returned by remote_open "100", # return a maximum of 100 events "1", # call will time out in one minute "\n\n", # separate each event with two newline characters # event output format: "event ID: %{EV_ID}\nevent type: %{EV_TYPE}\ndescription: %{EV_DESC}", # event filter: "", # any start time "", # any end time "O", # only OPEN status "A,W", # only ALARM AND WARNING states "", # any node "ORACLE", # ORACLE as an originating application "", # any pattern in the event description "" # any event class ) . "\n" );
4-234
remote_event_trigger()
Create an event instance for the PATROL Event Manager of a remote PATROL Agent
Format
remote_event_trigger(sessionID,"origin","catalog", "class","type","severity","argument1", . . . ,"argument20")
Parameters
Parameter sessionID Definition
The identifier of the remote PATROL Agent session to which the remote event trigger is directed. The sessionID is returned by the remote_open() function when you open a remote PATROL Agent session. Character string indicating the application instance or class that originated the event. Character string name of the PATROL catalog to which the event belongs. Character string name of the event in the class to which the event belongs. The event type as displayed in the PATROL Event Manager. Valid range: ALARM WARNING ERROR CHANGE_STATUS INFORMATION
severity argumentn
Integer value indicating the severity of the event. Valid range: 1 5 (5 is most severe) Optional arguments passed to the PATROL Event Manager and displayed in the event detailed report. This function permits a maximum of 20 arguments.
remote_event_trigger()
4-235
Description
The remote_event_trigger() function creates an event instance that appears in the PATROL Event Manager of a remote PATROL Agent identified by sessionID. The origin of the event instance is origin. The remote_event_trigger() function assumes that the event catalog and class are already defined in the PATROL Event Manager for the remote PATROL Agent. The remote_event_trigger() function does not return any values.
Note
The remote_event_trigger() function returns immediately after initiating the process. It does not wait for completion of the trigger. Therefore, if you use the remote_event_query() function immediately after the remote_event_trigger() function, the event may not yet exist on the remote host. You may want to use the sleep() function as a delay between the remote_event_trigger() and remote_event_query() functions when they are used together.
Example:
The following is an example of the remote_event_trigger() function.
remote_event_trigger( mysession, # session handle returned by remote_open() "myorigin", # event origin: myorigin "STD", # event catalog: STANDARD "41", # event class: 41 "ALARM" # event type: ALARM "5", # severity: 5 (most severe) "myarg" # dynamic argument 1 );
4-236
remote_file_send()
Send an ASCII file to a remote PATROL Agent
Format
remote_file_send(sessionID,"srcfilename","destfilename", "catalog","class","sendID","access")
Parameters
Parameter sessionID Definition
The identifier of the remote PATROL Agent session to which the file is sent. The sessionID is returned by the remote_open() function when you open a remote PATROL Agent session. Full path name of the local ASCII file that is to be sent to the remote PATROL Agent. Name to be given the ASCII file on the remote PATROL Agent host. The file is written to the path: $PATROL_REMOTE/destfilename
srcfilename destfilename
catalog
Name of the catalog to which the event generated by the file transfer belongs. Valid range: a PATROL event catalog name or "" indicating the STANDARD catalog. Name of the class to which the event generated by the file transfer belongs. Valid range: a PATROL event class name or "" indicating the RemProcess class. User-defined identifier for the file send operation.
class
sendID
remote_file_send()
4-237
Parameter access
Definition
Integer designating the access mode assigned to the destination file. In Unix, file access is defined using an octal representation of the binary rwxrwxrwx (read, write, execute) permissions for owner, group, and world. The access parameter is the decimal equivalent of the octal value used in Unix. To define the access parameter, determine the octal value for the file permissions and convert it to a decimal value. Valid range: 000-777 (octal) Default: 666 (octal) 438 (decimal) which gives read and write permission to owner, group, and world See Determining the Decimal value for access for more information on determining the value for the access parameter.
Description
The remote_file_send() function copies srcfilename from the host on which the function executes to destfiename on the PATROL Agent host identified by sessionID. The remote_file_send() function returns 1 if successful or 0 otherwise. There is no built-in limit to the size of the file that can be transferred. If the PATROL_REMOTE environment variable is defined for the remote host, the file is written to $PATROL_REMOTE. If the PATROL_REMOTE environment variable is not defined, the file gets written to $PATROL_HOME/remote on the remote PATROL Agent. The remote_file_send() function generates an event on the PATROL Agent host identified by sessionID for the file send operation using the catalog and class parameters. If the catalog and class parameters are omitted, the remote_file_send() function creates a the STANDARD catalog event RemProcess. See remote_open() on page 4-242 for more information on using the remote functions.
BMC Software, Inc., Confidential and Proprietary Information
4-238
The access parameter is the decimal equivalent of the octal representation of the binary rwxrwxrwx (read, write, execute) permissions for owner, group, and world used under Unix. The simplest way to determine the decimal equivalent is to determine the octal value for Unix and convert it to a decimal value.
Octal permissions in Unix
In Unix, the valid range for the file permissions is 000 777 where the first digit is the owner permission, the second digit is the group permission, and the third digit is the world permission. The permissions are assigned to octal values as follows: 0 1 2 3 4 5 6 7 = no access (---) = execute(--x) = write(-w-) = write and execute(-wx) = read(r--) = read and execute(r-x) = read and write(rw-) = read, write, and execute (rwx)
For Example, 666 is the octal value that would set the Unix file permissions to rw-rw-rw- which is read and write permission to the file for owner, group, and world.
Decimal Permissions
The octal values for permissions are easy to determine. To determine the access parameter for the remote_file_send() function, start with the octal value and convert it to a decimal value. See convert_base() on page 4-47 for information on using the PSL convert_base() function to convert octal to decimal.
remote_file_send()
4-239
Table 4-5 compares the decimal and octal values for common file permissions.
Table 4-5 Decimal and Octal File Permissions
Octal
444 664 666 744 770 777
Decimal
292 436 438 484 504 511
For more information on Unix file permissions, see the chmod(1) user command in your Unix documentation.
4-240
Example
The following is an example of the remote_file_send() function where the access parameter is set as an octal value of 744 (read, write, and execute access for the owner and read access for the group and worldrwxr--r-- ) and then converted to a decimal value using the convert_base() function.
# set the file permission as an octal value of 744 for rwxr--r-octal_access=744; # convert the octal permission to a decimal for the remote_file _send() decimal_access=convert_base(octal_access,8,10); remote_file_send( mysession, "/tmp/myfile", "myremotefile", "", "", "myfileID", decimal_access );
# # # # # # #
session handle returned by the remote_open() function name of file to send name of file on remote PATROL Agent host STANDARD catalog for file send event RemProcess class for file send event myFileID identifies this file send operation file access permission of rwxr--r--
remote_file_send()
4-241
remote_open()
Open a communication session with a remote PATROL Agent
Format
remote_open("host","port","account-mode","username", "password","options")
Parameters
Parameter host port account-mode Definition
Host name on which the remote PATROL Agent is running UDP or TCP/IP port number on which the remote PATROL Agent is listening Optional account information that is used to open the session with the remote PATROL Agent Valid range: "" or omitted  ignore username and password and use the account information from:  the nearest instance  the parent of the nearest instance  the application to which the nearest instance belongs "NONE"  use the unencrypted username and password "pem"  use the encrypted username and password
username password
User name that is required to open a session with the remote PATROL Agent Password that is required to open a session with the remote PATROL Agent. The password may or may not be encrypted.
4-242
Parameter options
Definition
A comma delimited list of options in the following format: "protocol=UDP,timeout=nnn,retries=nnn,heartbeat=nnn"  protocolthe default protocol for this function is UDP, but it can be changed to TCP with the options parameter. The following options only apply to the UDP protocol:  timeoutthe maximum time in seconds that the function waits for the communication session to start  retriesthe maximum number of times that the function tries to establish a communication session  heartbeatthe number of seconds between attempts to keep the UDP connection open
Description
The remote_open() function opens a communication session between the PATROL Agent on which it is running and the PATROL Agent identified by host and port, using UDP unless TCP is specified in the options parameter. If account = "NONE", the remote_open() function uses the unencrypted username and password to open the session, both must be valid on the remote PATROL Agent. If account = "" or is omitted, the remote_open() function uses the account information from the nearest instance, instance parent, or application. The remote_open() function returns the session ID if successful; otherwise, it returns the NULL string.
Note
If you are using the remote functions across a firewall, you must set the PATROL Agents /AgentSetup/localPortForRemoteOpen configuration variable to the local UPD port number that will be used for the remote_open() function. This port must be different than the PATROL Agents port if you are sending files across a firewall. See the PATROL Agent Reference Manual for more information on setting PATROL Agent configuration variables.
remote_open()
4-243
To effectively use these functions, it is important to understand how these functions work together.
Understanding Remote Functions
The remote_open() function connects to a remote agent, supplies authentication information, and returns immediately. It does not wait for the authentication to take place. The user must ensure that the username/password information being supplied in the remote_open() function is a valid username/password on the remote PATROL Agent. An invalid username/password causes the remote PATROL Agent to reject the session id. This can shut down an operation before it is complete. Since the remote_open() function can return a session id when the authentication fails, there is no guarantee that the session id can be used to communicate with the remote agent. The remote_file_send() function transfers an ASCII file to a remote PATROL Agent. However, the function only starts the operation and returns immediately. The actual file transfer takes place in the background. The remote_file_send() function does not verify that the file transfer was successful. Therefore, you must ensure that the file transfer has been completed prior to using the remote_close() function to close the session with the remote agent. When the file transfer is complete, an event is generated on the remote agent indicating that the file has been transferred. If the remote_file_send() catalog and class parameters are not supplied, an event with the following characteristics will be generated on the remote target host:
Event Class = RemProcess Origin = PEM/DS,
BMC Software, Inc., Confidential and Proprietary Information
4-244
However, by supplying an event catalog and event class to the remote_file_send() function, you can define the event that gets generated. You could ensure that the file transfer is complete by waiting for this event to be generated on the remote PATROL Agent using the remote_event_query() function.
Example
The following example sends a file to a remote agent and creates two events on the remote agent if the transfer is successful:
targetHost="<myhost>"; targetPort="<myport>"; user="<myuser>"; password="<mypassword>"; myencrypted_passwd = encrypt(password, "PEM"); source_file = "<full path to myfile>"; remote_file = "<myfile>"; print("Start remote_file_send example at ".asctime(time(),"%H:%M:%S %m-%d-%Y")."\n"); printf("TargetHost <%s> on Port <%s>\n", targetHost, targetPort); printf("User <%s> Password <%s>\n", user, password); # Open session to remote Agent print("Open the channel.\n"); sess=remote_open(targetHost, targetPort, "PEM", user, myencrypted_passwd); print("errno=".errno."\n"); printf("Session #<%s> \n", sess); #print("Sleep 5 seconds.\n"); #sleep(5); print("Send the file.\n"); if (!sess) { error = "Error opening session to the Patrol Agent on the target Machine\n". "Please make sure the values are correct for:\n". " Target Host: " . targetHost."\n". " Target Port: " . targetPort."\n". " Username: ". user."\n". " Password: ". password."\n"; print(error); } else { #+++ # We have a session so try and send the file to remote agent # Specify the absolute path for the dest. file # Set the permissions to -rw-rw-rw- 666 Octal = 438 Decimal #--if (!remote_file_send(sess,source_file,remote_file,"STD","RemProcess","<myid>","438")) { # remote_file_send failed. Print error message\n". error = "Error sending file to the Patrol Agent on the target Machine\n". "Please make sure the values are correct for:\n".
BMC Software, Inc., Confidential and Proprietary Information
remote_open()
4-245
} else { #+++ # Wait for the file to transfer by searching for its logged event # This will wait for 30 seconds for the transfer to complete then # it gives up. #--wait_loops = 15; while (wait_loops > 0) { sleep(2); cmd_data = remote_event_query(sess, # Session ID "1", # return a maximum of 1 event "1", # time out in one minute "\n", # separate events with newline "Event ID <%{EV_ID}>", # return event id triggered "", # any start time "", # any end time "O", # only OPEN status "", # only INFORMATION type "", # any node "PEM/DS", # origin remote_file, # file name in descirption "", # any ID range "RemProcess", # RemProcess event class "" # any severity ); if (cmd_data != "") { wait_loops = 0; } else { wait_loops--; } } if (cmd_data == "") { error= "Error: remote_event_query was unable to verify remote_file_send()\n". "Please check the Event Manager on target:\n". " Target Machine: " . targetHost."\n". " Target Port: " . targetPort."\n"; print(error); } else { print("remote_file_send verified by remote_event_query: ".cmd_data); } } #+++ # Close up the sesssion with the remote agent #--remote_close(sess); }
4-246
The previous example creates the following events on the remote agent if the transfer is successful:
Event Class: Type: Origin: Description: Event Class: Type: Origin: Description: RemProcess INFORMATION PEM/DS File <myfile>, Operation (W), Stream Id <myid> Disconnect INFORMATION <Source hostname> Console U:7424.3379@<source host IP address> disconnected.
The following example uses all the remote functions to access a remote PATROL Agent.
# $Id: remote_psl_exec.psl,v 1.6 1996/03/09 23:46:41 mmattini Exp $ # # remote_psl_exec.psl #-------------------------------------------------------------# Description: Remote PSL execution. # # You need to run two agents for this example: # From (localhost, port 1234) you want to execute a remote PSL # script on (remotehost, port 5678). # # The PSL script (see your_psl_cmd below) is any PSL # statement which return a string. It will be executed on # (remotehost, port 5678) using PATROL console #-------------------------------------------------------------# Author : Max Mattini # Creation date : Jan 19, 1996 # # Last check-in date: $Date: 1996/03/09 23:46:41 $ # # Copyright (c) 1996 BMC Software, Inc. #-------------------------------------------------------------#
# The remote agent where the PSL script is to be executed remote_host = "remotehost"; remote_port = "5678"; # Your account details your_username = "username"; max_time_to_wait = "1"; your_id = "my_id"; # # # # maximum time (in minute) the PSL process will block waiting for the result. A local id provided by your KM to resolve any conflicts with other queries # replace with remote host name # replace with remote Agent port
# # # #
PSL script to be executed by <remote_host> It should return a string. Increase <max_time_to_wait> if this script will take a lot of time
your_psl_cmd= "get_vars(\"/\");"; #
BMC Software, Inc., Confidential and Proprietary Information
remote_open()
4-247
# 0. Use an already encrypted password if you dont want to store # the password in the KM. It is recommended that: # # - you encrypt your real password using encrypt() # - you store the encrypted password in a file or in the KM # use "pem" encryption it is safer than "des": # "pem" encryption is "des" encryption combined with an internal # encryption. Storing the result of a "pem" encryption is safe # since it cannot be used to log to any Unix (or other) systems. # your_pwd = "becool"; your_encrypted_pwd = encrypt(your_pwd,"pem"); # # 1. Open the remote connection with agent (nanou,5678); # sess=remote_open( remote_host, remote_port, "pem", your_username, your_encrypted_pwd ); print("Session number result of remote_open:".sess."\n"); print("Sending command: " . your_psl_cmd . "\n"); # # Dispatch the remote PSL. # trigger_res = remote_event_trigger( sess, remote_host, # Name of remote host "STANDARD", # Name of event catalog "RemPsl", # Name of event class in StdEvents.ctg "INFORMATION","5", # Type and severity your_psl_cmd, # First argument to <ev_exec_name> your_id # Second argument to <ev_exec_name> # This local id will uniqly identify # the result of the PSL exec. ); print("Result of trigger->".trigger_res."\n"); query_res=remote_event_query( sess, "1", # Finish query when 1 event is found max_time_to_wait, # Time in min. PSL process will block "", # N/A (event separator) "%{EV_ARG1}\n", # Format to print result of query "","", # Any start/end time "", # Any Status "", # Any Event Type "", # any node "", # any origin your_id, # pattern in filter should be your local id "", # match any eventid range in filter "Result" # match only event from class Result ); print( "Result of remote PSL execution on (" . remote_host . "," . remote_port . "):\n" . query_res ."<------\n"); # # Send the file to remote agent
BMC Software, Inc., Confidential and Proprietary Information
4-248
# # # # # # # # # # # #
The remote agent will write the content of file "/tmp/MyFile" in "$PATROL_REMOTE/MyRemoteFile". Also standard event RemProcess will be sent to the remote agent carrying the three dynamic arguments: - /tmp/MyFile - Operation (reserved for future use) - MyFileId A notification commnad can be executed at the remote agent to complete the processing of the file sent
transfer_res = remote_file_send( sess, # remote session handle "/tmp/MyFile", # full source file name "MyRemoteFile", # destination name in $PATROL_REMOTE "STD","RemProcess", # Use standard event FileProcess "MyFileId" # my id to identify this operation ); print("Result of transfer->".transfer_res."\n"); close_res = remote_close(sess); print("Result of close->".close_res."\n");
remote_open()
4-249
remove()
Remove a file from the file system
Format
remove("filename")
Parameters
Parameter filename Definition
The the name and path of the file to be removed from the file system
Description
The remove() function removes a specified file, filename from the file system. The full path of the file must be included in the filename parameter. The remove() function returns 1 if the file was successfully removed from the file system and returns 0 if the file could not be removed from the file system. The remove() function could be unsuccessful for various reasons, including insufficient file permissions or an invalid filename.
4-250
Example
The following PSL statements use the file() function to verify the existence of a file, and then attempts to remove the file using the remove() function. If the file exists but cannot be removed, a message is returned stating that the file properties and user permissions should be checked.
file_name="D:\\temp_data.txt"; if (file(file_name)) { print("\nFile (".file_name.") exists!\n"); if (remove(file_name)) { print("\nFile (".file_name.") removed!\n"); } else { print("\nFile (".file_name.") could not be removed!\n\nCheck file properties and user permissions!"); } } else { print("\nFile (".file_name.") does not exist!\n"); }
remove()
4-251
replace()
Replace a specified string in text with a specified replacement string
Format
replace("text","str","replacement_str")
Parameters
Parameter text str replacement_str Definition
Original text Text string to be found in text Text string to replace str that is found in text
Description
Use the replace() function instead of PSL common string manipulation techniques. All occurrences of str in text are replaced with replacement_str, and the result is returned.
Example
The following example demonstrates the replace() function:
new_text = replace("Hello there","there","world");
This example replaces the string "Hello there" with the following string:
Hello world
4-252
response()
Display a dialog on the PATROL Console
Format
response(title,timeout,preferences,. . . element definitions . . .)
Parameters
Parameter title timeout Definition
Character string that is the title of the dialog. The number of seconds that the agent will wait for acknowledgment of the dialog before canceling it. The timeout has the following properties:  If timeout = 0, the dialog is treated as a nonblocking notification that is equivalent to specifying N=1 in the preferences parameter. The response() function returns immediately without waiting for a PATROL Console response.  If timeout < 0 or timeout = "", then timeout is infinite.
response()
4-253
Definition
PSL list that specifies the properties of the dialog. Refer to page 4-255 for detailed information. PSL lists that define the fields that appear on the dialog. The following macro-like, built-in constants are valid elements: No. 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 Symbolic Name R_LABEL R_LABEL_CENTER R_SCALE_HORIZ R_SCALE_VERT R_SEP_HORIZ R_SEP_VERT R_RADIO_VERT R_RADIO_HORIZ R_CHECK_HORIZ R_CHECK_VERT R_MENU R_TEXT_FIELD R_TEXT_FIELD_LABEL R_TOGGLE R_FRAME R_ROW R_COLUMN R_LIST_SINGLE R_LIST_MULTIPLE R_ICON R_POPUP_SCROLLED R_POPUP R_LIST_SINGLE_ND R_LIST_MULTIPLE_ND R_SPINNER R_CLICKER Description Page label (left-justified) 4-272 label (centered) 4-272 sliding scale (horizontal) 4-285 sliding scale (vertical) 4-285 separator (horizontal) 4-284 separator (vertical) 4-284 radio box (vertical) 4-277 radio box (horizontal) 4-277 check box (horizontal) 4-262 check box (vertical) 4-262 option menu 4-273 text field (without label) 4-287 text field (with label) 4-287 toggle button 4-290 frame compound element 4-268 row compound element 4-280 column compound element 4-267 scrolled list (single-select, default) 4-281 scrolled list (multiple-select, defaults) 4-281 icon 4-270 popup (scrolled) 4-274 popup (nonscrolled) 4-274 scrolled list (single-select, no default) 4-281 scrolled list (multiple-select, no defaults)4-281 time spinner button 4-289 clicker widget 4-265
You can enter either the number or the symbolic name of these built-in constants to describe the graphical elements you want to display. Whenever a built-in constant is recognized in a PSL script, its value is substituted behind the scenes by the compiler. For example, consider the following function call: response("Some title","","",[R_CHECK_HORIZ,...] ...); The compiler will expand this to response("Some title","","",["8",...]...);
4-254
Preferences Format
You can specify the preferences using any one of three format variations:
PSL List Internal Representation (Newline Separated):
The PSL list operator format is much less efficient than either the PSL list internal representation or the character string representation.
Character String Format (Comma Separated):
Although the individual preference parameters are optional, the preferences string is required. Specify the NULL string "" to choose all the preference parameter defaults.
response()
4-255
w=width
Integer width of the dialog in pixels. Valid range: width> 0 specifies the width of the dialog in pixels width 0 specifies a dynamic width selected by the window manager Default if not specified: Dynamic width selected by the window manager
b=color
Character string that specifies the name of the dialog background color. Do not enclose the color character string in double quotation marks.
color maps the Motif internals of the PATROL Console machine. If Motif cannot resolve color, it substitutes the
color that the PATROL Console uses as a background in its dialogs. Default if not specified: Colors used by PATROL
H=id filename
Text string that enables a Help button on the response() function dialog box and specifies the file name and topic ID that the PATROL Console should display when the Help button is pressed. The H specification must consist of a numeric id and a string filename. The id and filename must be separated by a delimiter character: space, colon, or minus sign. DO NOT use commas, tab characters, or new-line characters because the response() function will interpret these characters as field delimiters. Default: If the H preference is not specified the Help button does not appear on the dialog box. If the H preference is specified but has no (or an unknown) id or filename, or both, the PATROL Console presents the Help general contents when pressed.
4-256
Parameter e=echo
Definition
Bit flag specifying whether text elements within the response dialog will (1) or will not (0) echo output to a text window. This parameter applies only to text elements types 11 and 12. Default if not specified: 1
o=oklabel o=@oklabel
Character string that replaces Accept on the OK button for the dialog and any popups activated from the dialog. Placing @ in front of the button name disables the button from closing the dialog when it is pressed, but should send a return value to the PATROL Agent and remain open for further user updates. (See Dynamic response() Function Dialog Boxes on page 4-293 and response_get_value() on page 4-311 for more information.) If you specify the o preference with no label (that is, "o="), the response() function does not display the Accept button on the dialog box. If you hide both the Accept and Cancel buttons, you must close the dialog box from PSL using the K preference.
response()
4-257
Definition
Character string that replaces Cancel on the Cancel button for the dialog and any popups activated from the dialog. Placing @ in front of the button name disables the button from closing the dialog when it is pressed, but should send a return value to the PATROL Agent and remain open for further user updates. (See Dynamic response() Function Dialog Boxes on page 4-293 and response_get_value() on page 4-311 for more information.) If you specify the c preference with no label (that is, "c="), the response() function does not display the Cancel button on the dialog box. If you hide both the Cancel and Accept buttons, you must close the dialog box from PSL using the K preference.
4-258
Parameter N=notify
Definition
Bit flag that specifies whether the dialog is editable or noneditable. Valid range: 0 dialog is editable.The response() function uses the timeout parameter to determine how long the PATROL Agent should wait for a response to the editable dialog. dialog is noneditable. The dialog is presented to the PATROL Console as a nonblocking notification dialog. The response() function returns immediately without waiting for a PATROL Console response. The PATROL Console will display the non-editable dialog box until the user closes it using either the OK or Cancel button.
A=ack-required
Bit flag that specifies whether the dialog requires an acknowledgment. Valid range: 0 Does not require explicit acknowledgment (that is, clicking on the Acknowledge button) of the dialog when presented to a single PATROL user (that is, when B=0). Requires explicit acknowledgment of the dialog in all cases.
Default: 0
B=broadcast
Bit flag that specifies who receives the response to the dialog. Valid range: 0 Return the dialog response to the PATROL Console that started the process that executed the response() function. Return the dialog response to all PATROL Consoles connected to the PATROL Agent that processed the response() function.
Default: 0
response()
4-259
Parameter D=dynamic
Definition
Bit flag that enables the response() function dialog box to be dynamically updated from a PSL script and multiple return values returned to, and processed by the PSL script before the dialog box is closed. (See Dynamic response() Function Dialog Boxes on page 4-293 and response_get_value() on page 4-311 for more information.) After the initial response() function call creates a dynamic dialog box, subsequent calls to modify the filed values do not require the D preference. The response() function will ignore the D preference if it is present. All dynamic response() function calls return immediately to the caller and do not use the timeout parameter. If you specify the timeout parameter on a dynamic response() function call, the response() function will ignore it. Valid range: 0 Disable dynamic updating of the dialog box. This mode is compatible with the response() function prior to PSL Version 3.1 Enable dynamic updating of the dialog box
Default: 0
K=enddialog
Bit flag that enables the PSL script that created this response() function dialog box to also close it. This preference can only be used against a response() function dialog box that was created using the D=1 preference. When specified, the dialog box will immediately close on all PATROL Consoles and return the closing status of the elements of the dialog box. This preference is for dynamic dialog boxes including those for which none of the existing dialog buttons will close the dialog box. Valid range: 0 1 Do not close the response() function dialog box Immediately close the dialog box on all Consoles and return a return value from the dialog box elements. Default: 0
4-260
Preferences Example
The following is an example of the preferences format using each of the three valid preferences formats:
PSL List Internal Representation:
# # # # # # # # # # # # # h=500 w=300 H=0 e=1 o=Accept c=Cancel N=0 A=0 B=0 D=0 K=0 H=1 exthlp dialog box height is 500 pixels dialog box width is 300pixels color change no help button on dialog box echo output to a text window Accept label on dialog box OK button Cancel label on dialog box Cancel button dialog box is editable acknowledgement is not required dialog box response is not broadcast dynamic updating is disabled do not close dialog box from this function call map help button to topic 1 in file exthlp
response()
4-261
You can specify the check boxes format using the PSL list internal representation or PSL list operator format.
PSL List Internal Representation: "check-type\ncheck1=cstate1\n...\ncheckn=cstaten"
4-262
If you do not specify the initial state of the check boxes, the response() function sets all boxes UNCHECKED. The check box field definition permits a maximum of 31 label definitions. If you require more than 31 definitions in the check box, BMC Software suggests that you create a multiple-select scrolled list. The handling of check box return values can be aided by the PSL set functions, especially the subset() function, which can be used to determine whether a given check box number is set in the return value.
Parameter check-type Definition
Integer value that identifies the list as a set of check box definitions. Valid range: 8 9 horizontal check box vertical check box
setstring
A character string in the form @1 b, . . . n where each n is an integer that specifies the position of a check box in the sequence of check box definitions check1 . . . checkn that is to default to CHECKED. All check box numbers not included in setstring default to UNCHECKED. The preceding @ character is required to differentiate setstring from a button definition. There must be no space or delimiter between the @ character and the first integer. Subsequent integers may be preceded by a single space, comma, or tab character. When setstring is specified, the response() function ignores any default settings that appear in the check box definitions. Specifying setstring = @0 sets all check boxes UNCHECKED and ignores any settings specified in the button definitions.
checkn=cstaten
checkn is a character string label for the nth check box. Do not enclose the checkn character string in double quotation marks. checkn may be specified as multiple lines of text. cstaten is the binary state of the check box. Valid range:
0 1 UNCHECKED CHECKED
response()
4-263
The following are examples of check boxes definition using the PSL list internal representation and the PSL list operator format. The definition creates a vertical list of three check boxes titled Yes, No, and Maybe. The Maybe check box is checked; the others are unchecked.
PSL List Internal Representation:
"R_CHECK_VERT\nYes=0\No=1\nMaybe=1"
or
"9\n@2 3\nYes\nNo\nMaybe"
or
[9,"@2 3","Yes","No","Maybe"]
4-264
Clicker Format
You can specify the clicker format using the PSL list internal representation or PSL list operator format.
PSL List Internal Representation:
"clicker-type\nlabel\nmin\nmax\ndefault-value"
PSL List Operator Format:
response()
4-265
Clicker Examples
The following are examples of the clicker definition using the PSL list internal representations and the PSL list operator format. The definitions create a clicker with a label of "Select a number," a minimum value of 0, a maximum value of 100, and a default value of 50.
PSL List Internal Representation:
"R_CLICKER\nSelect a number\n0\n100\n50"
or
[R_CLICKER, "Select a number", 0, 100, 50]
4-266
You can specify the column alignment compound element format using the PSL list internal representation or PSL list operator format.
PSL List Internal Representation:
The element definitions that are part of a column compound definition are placed vertically from top to bottom in the dialog or popup. The column is aligned along the left edge of the frame that contains it immediately beneath the previous element definition. Unless otherwise specified, all response() function definitions are aligned in a single row.
Parameter column-type celements Definition
Integer value identifying the list as a column definition. Valid range: 16 Integer value specifying the number of subsequent element definitions that are included in the column.
response()
4-267
The following are examples of column alignment compound element definition using the PSL list internal representation and PSL list operator format. The definition creates a column of three rows of radio buttons, three buttons in each row.
PSL List Internal Representation:
"R_COLUMN\n3", "R_RADIO_HORIZ\nYes=0\nNo=0\nMaybe=1", "R_RADIO_HORIZ\nDont Know=0\nDont Care=1\nGood-bye=0", "R_RADIO_HORIZ\nGreat=0\nGood=0\nSo-So=1",
You can specify the frame enclosure compound element format using the PSL list internal representation or the PSL list operator format.
PSL List Internal Representation:
4-268
The element definitions that are part of a frame compound definition are placed in an enclosed bordered region of the dialog or popup. The frame is aligned to  the left edge of the frame that contains it, if specified as a column element immediately to the right of the previous element definition, if specified as a row element
Note
The response() function ignores the felements parameter and sets its value to one. In order to define multiple elements in a frame, define a frame element and then define a row or column as the frames first subelement.
Definition
Integer value identifying the list as a frame definition. Valid range: 14 Integer value specifying the number of subsequent element definitions that are included in the frame.
felements includes nested compound element definitions but does not include the elements that are specified for those nested compound elements. Refer to Nested Compound Elements on page 4-293.
response()
4-269
The following are examples of frame enclosure compound element definition using the PSL list internal representation and PSL list operator format. The definition creates a frame enclosing a column of three rows of radio buttons, three buttons in each row.
PSL List Internal Representation:
"R_FRAME\n1", "R_COLUMN\n3", "R_RADIO_HORIZ\nYes=0\nNo=0\nMaybe=1", "R_RADIO_HORIZ\nDont Know=0\nDont Care=1\n Good-bye=0", "R_RADIO_HORIZ\nGreat=0\nGood=0\nSo-So=1",
Icon Format
You can specify the icon format using the PSL list internal representation or the PSL list operator format.
PSL List Internal Representation:
"icon-type\nicon-filename"
PSL List Operator Format:
[icon-type,"icon-filename"]
Icon Parameters
The creation of icons on the PATROL Console can sometimes consume significant processing time. Unless an icon is already cached internally, it takes time to load the image from disk.
4-270
The second time a given icon is requested, the performance penalty will disappear if the icon is still in cache. The performance penalty may also disappear if the icon already appears elsewhere within the Console GUI, though the caching effect leading to better performance may only occur if you have actually viewed the window in which the icon appears.
Parameter icon-type icon-filename Definition
Integer value identifying the list as an icon definition. Valid range: 19 Character string identifying the file containing the icon image. The icon-filename character string must be enclosed in double quotation marks. If the file extension is omitted, the response function assumes an extension of .gif.
Icon Example
The following are examples of the icon element definition using the PSL list internal representation and PSL list operator format. The definition places the BMC Software logo from the directory $PATROL_HOME/lib/images in the dialog box.
PSL List Internal Representation:
"19\nBMC.xbm",
response()
4-271
Label Format
You can specify the label format using the PSL list internal representation or PSL list operator format.
PSL List Internal Representation:
"label-type\nlabel"
PSL List Operator Format:
[label-type,"label"]
label
Character string that specifies the label that should appear on the dialog. The label character strings must be enclosed in double quotation marks. The label may be specified as multiple lines of text.
Label Example
The following are examples of the label definition using the PSL list internal representation and PSL list operator format. The definition creates a label for a BMC Software logo.
PSL List Internal Representation:
"1\nThe BMC Software logo follows:", "19\n$PATROL_HOME/lib/images/BMC.xbm",
4-272
You can specify the option menu format using the PSL list internal representation or PSL list operator format.
PSL List Internal Representation:
"option-type\nlabel\ndefault\noption1\n...\noptionn"
PSL List Operator Format:
[option-type,"label",default,"option1", . . . ,"optionn"]
default
optionn
response()
4-273
The following are examples of the option menu definition using the PSL list internal representation and PSL list operator format. The definition creates and option menu with the label Time and the choices Month, Day, Year, Hour, and Minute, defaulting to Day.
PSL List Internal Representation:
"R_MENU\nTime:\n2\nMonth\nDay\nYear\nHour\nMinute",
You can specify the popup compound element format using the PSL list internal representation or PSL list operator format.
PSL List Internal Representation:
The popup is a compound GUI element that is displayed as a subwindow only by clicking on a popup button in the parent window. The element definitions included in the popup definition are displayed in the popup window. The element definitions for popups can include other popups and compound elements as well as common element definitions (buttons, lists, check boxes, and so on).
4-274
Parameter pop-type
Definition
Integer value identifying the list as a popup definition. Valid Range: 20 21 scrolled popup nonscrolled popup
pelements
Integer value specifying the number of subsequent element definitions that are included in the popup
btitle
Character string that is the label for the popup button on the parent popup or dialog. Character strings must be enclosed in double quotation marks. The btitle may be defined as multiple lines of text. Default if not specified: Pop-up
ptitle
Character string that is the title of the popup. Character strings must be enclosed in double quotation marks. Default if not specified: Pop-up
h=pheight
Integer height of the popup in pixels. Valid range: pheight > 0 specifies the height of the popup in pixels pheight 0 specifies a dynamic height selected by the window manager Default if not specified: Dynamic height selected by the window manager
w=pwidth
Integer width of the popup in pixels. Valid range: pwidth> 0 specifies the width of the popup in pixels pwidth 0 specifies a dynamic width selected by the window manager Default if not specified: Dynamic height selected by the window manager
b=pcolor
Character string that specifies the name of the popup background color. Character strings must be enclosed in double quotation marks.
color maps the Motif internals of the PATROL Console machine. If Motif cannot resolve color, it substitutes the
color that the PATROL Console uses as a background in its popups.
response()
4-275
The following are examples of the popup compound element definition using the PSL list internal representation and PSL list operator format. The definition creates a popup that displays the time controls for a mythical time machine. The slide bar controls use the current time and date from an external asctime() function call as defaults.
PSL List Internal Representation:
"21\n1\nTime Machine\nTime Controls", "16\n4", "14\n1", "16\n2", "1\nClock Controls", "24\n" . current, "14\n1", "16\n4", "1\nCalendar Controls", "10\nmonth\n" . month . "\nJanuary\n" . "February\nMarch\nApril\nMay\nJune\n" . "July\nAugust\nSeptember\nOctober\n" . "November\nDecember", "2\nday\n1\n31\n" . day, "12\nyear\n" . int(year), "13\nAutomatic Return in 1 Hour\n1", "1\nWelcome to another time!", # # # # # # # # # # # # # # # # # *popup: column: frame: column: label *time spinner frame: column: label *option menu
4-276
You can specify the radio button format using the PSL list internal representation or PSL list operator format.
PSL List Internal Representation:
"radio-type\nradio1=rstate1\n...\nradion=rstaten" or alternately, using a string to specify the radio box rstaten: "radio-type\nsetstring\nradio1\n . . . \nradion"
PSL List Operator Format:
[radio-type,"radio1=rstate1", ... ,"radion=rstaten"]
response()
4-277
Radio Button Boxes require that exactly one of the radio buttons be ON and all the others be OFF. If you do not specify the initial state of the radio buttons, the response() function sets the first radio button ON and all the others to OFF by default.
Parameter radio_type Definition
Integer value that identifies the list as a set of radio button definitions. Valid range: 6 7 vertical radio box horizontal radio box
setstring
A character string in the form @n where n is an integer that specifies the position of a radio box in the sequence of radio box definitions radio1 . . . radion that is to default to ON. All other radio boxes default to OFF. The preceding @ character is required to differentiate setstring from a radio button definition. There must be no space or delimiter between the @ and the radio box number. When setstring is specified the response() function ignores any default settings that appear in the radio box definitions. If more than one integer is specified in setstring, the response() function uses the first integer and ignores all the rest.
radion=[rstaten]
Only one radio button in a radio button box is permitted to have state 1; all others must have state 0.
4-278
The following are examples of the radio button definition using the PSL list internal representation and PSL list operator format. The definition creates two columns of vertical radio buttons.
PSL List Internal Representation:
"R_ROW\n3", "R_RADIO_VERT\nUnix=1\nWindows NT=0\nOS/2=0", "R_SEP_VERT", "R_RADIO_VERT\nBinary=0\nText=0\nAutoselect=1" # # # # row compound element: radio button vertical separator radio button
or
"15\n3", "6\n@1\nUnix\nWindows NT\nOS/2", "5", "6\n@3\nBinary\nText\nAutoselect" # # # # row compound element: radio button vertical separator radio button
or
[15,3], [6,"@1","Unix","Windows NT","OS/2"], [5], [6,"@3","Binary","Text","Autoselect"], # # # # row compound element: radio button vertical separator radio button
response()
4-279
You can specify the row alignment compound element format using the PSL list internal representation or PSL list operator formats.
PSL List Internal Representation:
The element definitions that are part of a row compound definition are placed horizontally from left to right across the dialog or popup. The row is aligned beginning at the left edge of the frame that contains it immediately beneath the previous element definition.
Parameter row-type relements Definition
Integer value identifying the list as a row definition. Valid range: 15 Integer value specifying the number of subsequent element definitions that are included in the row.
relements includes nested compound element definitions but does not include the elements that are specified for those nested compound elements. Refer to Nested Compound Elements on page 4-293.
4-280
The following are examples of the row compound element definition using the PSL list internal representation and PSL list operator format. The definition creates a row with three elements: two columns of radio buttons and a vertical separator between them.
PSL List Internal Representation:
"R_ROW\n3", "R_RADIO_VERT\nUnix=1\nWindows NT=0\nOS/2=0", "R_SEP_VERT", "R_RADIO_VERT\nBinary=0\nText=0\nAutoselect=1" # # # # row compound element: radio button vertical separator radio button
You can specify the scrolled list format using the PSL list internal representation or PSL list operator format.
PSL List Internal Representation:
"scroll-type\nscroll1=sstate1\n . . . \nscrolln=sstaten"
PSL List Operator Format:
[scroll-type,"scroll1=sstate1", ... ,"scrolln=sstaten"]
response()
4-281
The scrolled list definition permits a maximum of 200 entry definitions. The handling of multiple-selection scrolled list return values can be aided by the PSL set functions, especially the subset() function, which can be used to determine whether a given list element number is set in the return value.
Parameter scroll-type Definition
Integer value that identifies the list as a scrolled list. Valid range: 17 18 22 23 single-selection scrolled list with default multiple selection scrolled list with default single-selection scrolled list without default multiple-selection scrolled list without defaults
If scroll-type is 22 or 23, the response() function ignores the equal sign (=) and any values specified in the list definition. (This allows you to specify display text that contains equal signs.) For scrolled lists without defaults, all entries are UNSELECTED (that is, equal to zero).
scrolln=sstaten
scrolln is a character string that is the label for the nth entry in the scrolled list. The scrolln may be specified as multiple lines of text. sstaten is the binary state of the nth scrolled list entry.
Valid range: 0 1 UNSELECTED SELECTED
If no states are specified for the scrolled list entries, all states default to 0 (UNSELECTED).
4-282
The following are examples of the scrolled list definition using the PSL list internal representation and PSL list operator format. The definition creates four scrolled lists: single-select with default, multiple select with default, single-select without default, multiple-select without default.
PSL List Internal Representation:
"0\nOur Menu:", "15\n4", "17\nWater=1\nCoffee=0\nTea=0\nWine=0", "18\nOkra=1\nPeas=1\nCorn=0\nSquash=0", "22\nBeef\nHen\nPork\nFish\nNone", "23\nCake\nPie\nFruit\nMint\nCandy", # label element # row compound element: # scrolled list (sngl,def) # scrolled list (mult,def) # scrolled list (sngl,~def) # scrolled list (mult,~def)
response()
4-283
You can specify the separator format using the PSL list internal representation or PSL list operator format.
PSL List Internal Representation:
"separator-type"
PSL List Operator Format:
[separator-type]
The separator places blank space on the dialog and allows you to format and group the other fields you place on the dialog.
Parameter separator-type Definition
Integer value that identifies the list as a separator definition. Valid range: 4 5 horizontal separator vertical separator
The following are examples of the separator definition using the PSL list internal representation and PSL list operator format. The definition separates two columns of radio buttons with a vertical separator.
PSL List Internal Representation:
"R_ROW\n3", "R_RADIO_VERT\nUnix=1\nWindows NT=0\nOS/2=0", "R_SEP_VERT", "R_RADIO_VERT\nBinary=0\nText=0\nAutoselect=1" # # # # row compound element: radio button vertical separator radio button
4-284
You can specify the sliding scale format using the PSL list internal representation or PSL list operator format.
PSL List Internal Representation:
"sliding-scale-type\nscale-label\nminimum\nmaximum\ninitial"
PSL List Operator Format:
[sliding-scale-type,"scale-label",minimum,maximum,initial]
The response() function performs the following consistency checks on the sliding scale minimum, maximum, and initial values:   If minimum > maximum, set maximum = minimum + 100 If initial < minimum or initial > maximum, set initial = (minimum + maximum) / 2
Parameter sliding-scale-type Definition
Integer value that identifies the list as a sliding scale definition. Valid range: 2 3 horizontal sliding scale vertical sliding scale
scale-label
Character string label for the sliding scale. The scale-label character string must be enclosed in double quotation marks. The scale-label may be specified as multiple lines of text. Numeric value specifying the lower limit of the sliding scale. Default if not specified: 0
minimum
maximum
Numeric value indicating the upper limit of the sliding scale. Default if not specified: 100
response()
4-285
Parameter initial
Definition
Numeric value indicating the initial position of the scale pointer on the sliding scale. Default if not specified: Midway between minimum and maximum.
The following are examples of the sliding scale definition using the PSL list internal representation and PSL list operator format. The definition pops up a set of sliding bar time machine controls defaulting to the current date and time.
PSL List Internal Representation:
"21\n1\nTime Machine\nTime Controls", "16\n3" "14\n1", "16\n4", "1\nClock Controls", "2\nseconds\n0\n59\n" . seconds, "2\nminutes\n0\n59\n" . minutes, "2\nhours\n0\n23\n" . hours, "14\n1", "16\n4", "1\nCalendar Controls", "2\nday\n1\n31\n" . day, "2\nmonth\n1\n12\n" . month, "2\nyear\n1\n12\n" . year, "1\nHappy Landing!", # # # # # # # # # # # # # # # popup dialog box: column compound element: frame compound element: column compound element: label element slide bar element slide bar element slide bar element frame compound element: column compound element: label element slide bar element slide bar element slide bar element label element
4-286
You can specify the text field format using the PSL list internal representation or PSL list operator format.
PSL List Internal Representation:
"text-type\ntext-label\ndefault-text\ne=text-echo-status"
PSL List Operator Format:
[text-type,"text-label","default-text","e=text-echo-status"]
text-label
Character string label for the text box. Character strings must be enclosed in double quotation marks. The text_label may be specified as multiple lines of text. This field is not valid if text-type=11. Character string that is the default text within the text box. Character string that specifies whether text typed into the text box is displayed. Valid range: 1 0 Display entered text Blank out entered text
default-text
e=text-echo-status
Default: 1 Note that you can use the echo mode to blank out text entry into text fields that contain sensitive information, such as passwords.
response()
4-287
The following are examples of the text field definition using the PSL list internal representation and PSL list operator format. The definition creates user name and password boxes. The password box blanks entered text.
PSL List Internal Representation:
"R_TEXT_FIELD_LABEL\nUsername:\n\ne=1", "R_TEXT_FIELD_LABEL\nPassword:\n\ne=0", # # text field (echo text) text field (blank text)
4-288
You can specify the time spinner button using the PSL list internal representation or the PSL list operator format.
PSL List Internal Representation:
"spinner\ntimestamp"
PSL List Operator Format:
[spinner,timestamp]
Time Spinner Button Parameters Parameter spinner timestamp Definition
Integer value identifying the element as a time spinner button. Valid range: 24 Integer value that specifies the current time (in seconds past midnight) that will be displayed on the spinner button. The spinner button converts and displays the time in hh:mm:ss format. Valid range: 0  86,399
The following are examples of the time spinner button definition using the PSL list internal representation and PSL list operator format.
PSL List Internal Representation:
"24\n" . time; # *spinner
response()
4-289
You can specify the toggle button format using the PSL list internal representation or PSL list operator format.
PSL List Internal Representation:
"toggle-state\ntoggle\ntstate"
PSL List Operator Format:
[toggle-type,"toggle",tstate]
toggle is a character string that is the label for the toggle button. Character strings must be enclosed in double quotation marks. The toggle may be defined as multiple lines of text. The state of toggle defaults to OFF.
Initial state of the toggle button. Valid range: 0 1 OFF ON
tstate
The following are examples of the toggle button definition using the PSL list internal representation and PSL list operator format.
PSL List Internal Representation:
"R_TOGGLE\nAutomatic Return in 1 Hour\nR_LABEL_CENTER", # toggle button element
4-290
Description
The response() function helps you create a GUI for your programs. Use the response() function to create a dialog box on the PATROL Console by constructing the box using the dialog box preferences and by populating it with the specified GUI control elements. Each response() function call will accept a maximum of 100 element definitions. The dialog box is displayed in a scrolled window. The scroll bars will appear if the dialog is large or if the window is resized to be smaller than the underlying dialog size.
where type is an integer that identifies a GUI control element type and the datan specify the attributes specific to the control element. The type and datan attributes are separated by new-line characters.
response()
4-291
The following GUI control element types are available: radio boxes (horizontal and vertical) check boxes (horizontal and vertical) text fields separator (dummy) fields sliding scales (horizontal and vertical) option menus labels and centered labels single-select and multiple-select scrolled lists icons toggle buttons row alignment compound element column alignment compound element frame enclosure compound element popup compound element time spinner button
By default, every definition that follows a compound element definition is part of the compound element. The compound element definition includes a value that specifies the number of subsequent element definitions that belong to the compound element. The response() function reads the value and processes the correct number of elements into the compound element. Any remaining element definitions are processed for the parent of the compound element.
4-292
box elements
response()
4-293
The dynamic response() function is implemented using the D preference: When D=0, the response() function creates a standard dialog box and when the dialog box closes returns the status of the dialog box elements When D=1, the response() function creates a dynamic dialog box and returns the rid for it. (You use the response_get_value() function to return the status of the dialog box elements.)
To create a dynamic response() function dialog box, call the response() function with the D=1 preference. The return value from the call is the rid:
dialogID = response("Title","","D=1", . . . elements . . . );
Subsequent calls to update the dialog box with new values use the rid in place of the dialog box title:
success = response(dialogID,"","D=1", . . . elements . . . );
Note
Specifying the D preference in subsequent response() function calls to the dynamic dialog is optional. The response() function ignores the D preference in calls that specify rid instead of a title string. If the subsequent response() function is successful, it returns 1 and sets the PSL variable errno = 0 (E_PSL_NO_ERROR). If the rid is invalid or no longer exists, the subsequent response() function returns 0 but does not set the PSL variable errno and does not produce a message. If the rid is so badly defined in a subsequent response() function that it is not recognizable as an rid, the response() function will assume it is a title and will create a dialog box with it as a title.
4-294
When the D preference is omitted, or when D=0, the response() function performs exactly as it did prior to the addition of the dynamic response() function feature. Once a dynamic response() function dialog box has been created, further use of the D option in subsequent response() function calls to rid is unnecessary. The response() function calls to a dynamic dialog box ignore the D option. Dynamic response() function calls ignore any specified timeout and immediately return an rid or operation status value: If title and D=1 are specified, the response() function returns a new and unique rid based on host name and ID and open a new dynamic dialog box on the PATROL Console display. If rid is specified in place of title, the response() function sets the element values included in the response() function call and returns a 0 or 1 status value. (The state of the D option is irrelevant when an rid is specified in place of title.)
response()
4-295
Once a dynamic dialog box has been created and the rid returned, subsequent response(rid, . . . ) function calls have the following features: Each returns 1 if successful or 0 otherwise. All updates to the elements of the dynamic dialog box are immediately visible to the user All updates overwrite any changes the user has made to the dynamic dialog box. The updated dynamic dialog box reflects the element definitions in the response() function call. If an element on the dynamic dialog box was modified by a user, and a response() function call to the dialog box did not modify the element, then the user modification will remain unchanged after the response() function is processed
Along with these features, subsequent response(rid, . . . ) function calls to a dynamic dialog box have the following restrictions: You must match the arguments in subsequent response() function calls with the arguments in the original dynamic response function call. That is, if you want to update the nth element from the original response() function definition, it must be the nth element in the subsequent response(rid, . . . ) call. The response() function will not allow you to replace one element type with another. The response() function will ignore any and all element definitions in a subsequent response() function call that do not match the original call. The response() function cannot be used to change the structure of a dynamic dialog box, the number of elements in the dialog box, or their order. The response() function can only change the values of certain elements in the dialog box.
4-296
The response() function cannot be used to change the preferences of a dynamic dialog box such as the background color or the label of the OK or Cancel button. The response() function will accept empty strings ("") as place holders and to represent element definitions that you do not wish to modify. (Use the empty strings: repeatedly passing the original element definitions in subsequent response() function calls is inefficient because the response() function will interpret and replace the value each time even though it is unnecessary.)
Table 4-6 lists those response() function elements that can and cannot be updated with new values using a subsequent response() function call. Elements can be updated in either a dialog box or its popups. (The popup element cannot be updated, but the elements defined within it can be updated.
Table 4-6 Elements that a Dynamic response() Function Can Update
Can Update:
label (types 0, 1) sliding scale (types 2, 3) radio box (types 6, 7) check box (types 8, 9) text field (types 11, 12) toggle button (type 13) scrolled list (types 17, 18, 22, 23)
Cannot Update:
separators (types 4, 5) icon (type 19) popup (types 20, 21) frame (type 14) column (type 16) row (type 15) option menu (type 10) time spinner (type 24)
The response() function return value is a PSL list separated by new-line characters that consists of a status value and return values from the dialog box elements in the form
status\n returnvalue01\n returnvalue02\n ... returnvaluen
response()
4-297
where each returnvaluen is a return value from one of the response() function dialog box elements. The order of the return values is the order that the elements were defined in the response() function. The following elements do not return values (not event newline place holders): labels (element types 0 and 1) separators (element types 4 and 5) frames (element type 14) row and column compound elements (element types 15 and 16) icons (element type 17)
The following is a summary of the elements that return values. The elements are listed in order by element number following a description of the response() function status value that is always the first line of the return value.
Return Value Definition
4-298
Return Value
Check Boxes (elements 8 and 9)
Definition
Format: cstate1 cstate2 . . . cstaten\n a space-separated row of integer values identifying the check boxes that are CHECKED(1). The cstaten values are listed in order of the check box definitions in the response() function. If no check boxes are selected, the return value is zero. Format: option_number\n an integer value indicating the option number selected from the option menu. The options are numbered in order of their definition in the response function, beginning with number 1. Each option menu returns exactly one option. Format: text_string\n a character string value that was typed into the text field. The text_string is a single line of text containing no new-line characters. The response() function return value method prevents the user from entering a new-line characters in a text field request. The user can only enter one line of text.
Toggle Button (element 13) Single-Select Scrolled Lists (elements 17 and 22)
Format: tstate\n a binary value indicating that the toggle switch is ON (1) or OFF (0). Format: scroll_number\n an integer value identifying the scroll list entry that is SELECTED in the single-selection scroll list. The scroll list entries are numbered in order of their definition in the response() function, beginning with number 1. Each radio box returns exactly one scroll_number. If no scroll list entry is selected, the return value is zero.
Format: mscroll1 mscroll2 . . . mscrolln\n a space-separated row of integer values identifying the n multiple-selection scroll list entries as SELECTED (1) or UNSELECTED (0). The mscrolln values are listed in order of the scroll list definitions in the response() function. If no scroll list entries are selected, the return value is zero.
response()
4-299
Return Value
Time Spinner (element 24)
Definition
Format: elapsed\n an integer value that is the number of seconds that were indicated in the hours, minutes, and seconds windows of the spinner button. elapsed is determined using the conversion:
Note that the first two status values give no indication whether the popup was open when its parent was closed. For example, the user could display the popup, click Cancel, display it again, change the content, and close the main window with the popup still open. In this case, pop_state = 0 because the popup was last closed using the Cancel button. Clicker (element 25) Format: value\n an integer value identifying the value on the clicker
Regardless whether status is 0 or 1, the response() function returns the full list of return values. The return of a full list of values allows the Knowledge Module developer to choose whether to take different actions depending on whether the user clicked OK or Cancel.
4-300
When a response() function timeout occurs, that is, when the PATROL Console does not acknowledge a response() function dialog within the timeout period, the PATROL Agent wakes the process that called the response() function, returns the empty string as the response() function return value, and sets the PSL variable errno = 86 (E_PSL_RESPONSE_TIMEOUT). A response() function timeout is not equivalent to pressing Cancel on the response() function dialog. Pressing Cancel causes the response() function to return to the calling process a return value containing status = 0 (dialog canceled) along with a full list of return values from the individual dialog controls.
Multiple response() Function Dialogs
The PATROL Console will display multiple response() function dialogs as it receives them from the PATROL Agent. There is no restriction on the number of response() function dialogs that the PATROL Console is permitted to display at any given time. The number of dialogs displayed is controlled solely by the number of PSL processes executing within the PATROL Agent that are making response() function calls.
The response() Function and the PATROL Event Manager
Calls to the response() function are integrated with events processed by the PATROL Event Manager. The current status of a response() function event, whether Open, Acknowledged, or Closed, is shown by the Event Manager display. You can acknowledge a response() function event in either of the following ways: 1. clicking on Acknowledge in the response() function event popup 2. selecting the event and clicking on Acknowledge in the Event Manager display
response()
4-301
In either case, assuming acknowledgment succeeds, the status change appears in the following places: 1. Event Manager display 2. response() function requests list window 3. response() function dialog window In the case of the response() function dialog window, the status is mirrored in the sensitivity of the response() function event popup, corresponding to the response() function event, rather than actually being displayed. This consistency across the three locations should apply to any status change in the response() function event. A response() function event popup can be displayed from within the Event Manager by selecting the event and clicking on Answer.
Example
The following PSL script combines all the previous element examples to produce a response() function dialog box using PSL list internal representation and PSL list operator definitions. The script consists of:  a response_analysis() function that decodes and provides a text summary of the response() function return value: a main() function that displays the response dialog and then calls the response_analysis() function to decode the return value.
The response() function contains comments to assist you in recognizing the element definitions.
4-302
function response_analysis(status) { # status line 1 is the check box status print("Check box status:\n"); checks = nthlinef(status,1); i = 1; temp = nthargf(checks,i); while(temp) { switch (temp) { case 1: {print(" Yes is checked\n");} case 2: {print(" No is checked\n");} case 3: {print(" Maybe is checked\n");} } i++; temp = nthargf(checks,i); } print("\n"); # status lines 2 through 4 are the framed rows of radio boxes statuses: print("Radio box frame status:\n"); i = 2; while (i <= 4) { switch (i) { case 2: {label = ["Yes","No","Maybe"];} case 3: {label = ["Left","Center","Right"];} case 4: {label = ["More","Enough","Less"];} } radio = int(nthlinef(status,i)); switch (radio) { case 1: {print(" ",trim(nthlinef(label,1),"\n")," is selected\n");} case 2: {print(" ",trim(nthlinef(label,2),"\n")," is selected\n");} case 3: {print(" ",trim(nthlinef(label,3),"\n")," is selected\n");} } i++; } print("\n"); # status line 5 is the option menu status print("Option menu status:\n"); option = int(nthline(status,5)); switch (option) { case 1: {print(" Month is selected\n\n");} case 2: {print(" Day is selected\n\n");} case 3: {print(" Year is selected\n\n");} case 4: {print(" Hour is selected\n\n");} case 5: {print(" Minute is selected\n\n");} } # status line 6 is the popup close status print("Popup dialog close status:\n"); popup = int(nthline(status,6)); switch (popup + 1) { case 1: {print(" Popup was displayed and closed using Cancel\n\n");} case 2: {print(" Popup was displayed and closed using Accept\n\n");} case 3: {print(" Popup was not displayed\n\n");} case 4: {print(" Popup was open when parent dialog closed\n\n");} }
response()
4-303
# status lines 7 through 10 are the time control values print("Time control settings:\n"); control_time = trim(nthlinef(status,7),"\n"); hours = int(control_time / 3600); printf(" hours control is set to %d\n",hours); control_time = control_time - (hours * 3600); minutes = int(control_time / 60); printf(" minutes control is set to %d\n",minutes); seconds = control_time - (minutes * 60); printf(" seconds control is set to %d\n",seconds); month_string = [ "January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December" ]; printf(" month control is set to %s",nthlinef(month_string,trim(nthlinef(status,8),"\n"))); i = 9; while (i <= 10) { quantity = ["day","year"]; print(" ",trim(nthlinef(quantity,i - 8),"\n")," control is set to ",nthlinef(status,i)); i++; } print("\n"); # status line 11 is the toggle status print("Automatic return toggle status:\n"); if (int(nthlinef(status,11)) == 1) { print(" Automatic return in 1 hour is set\n\n"); } else { print(" Automatic return in 1 hour is NOT set\n\n"); } # status lines 12 and 13 are the vertically separated radio box statuses: print("Radio box status:\n"); i = 12; while (i <= 13) { switch (i) { case 12: {label = ["Unix","Windows NT","OS/2"];} case 13: {label = ["Binary","Text","Autoselect"];} } radio = int(nthlinef(status,i)); switch (radio) { case 1: {print(" ",trim(nthlinef(label,1),"\n")," is selected\n");} case 2: {print(" ",trim(nthlinef(label,2),"\n")," is selected\n");} case 3: {print(" ",trim(nthlinef(label,3),"\n")," is selected\n");} } i++; } print("\n");
4-304
# status line 14 is the single-select scrolling menu with default print("Single-select scrolling menu status:\n"); option = int(nthline(status,14)); switch (option) { case 1: {print(" Water is selected\n\n");} case 2: {print(" Coffee is selected\n\n");} case 3: {print(" Tea is selected\n\n");} case 4: {print(" Wine is selected\n\n");} } # status line 15 is the multiple-select scrolling menu with default print("Multiple-select scrolling menu status:\n"); option = nthlinef(status,15); i = 1; temp = nthargf(option,i); while(temp) { switch (temp) { case 1: {print(" Potatoes are selected\n");} case 2: {print(" Peas are selected\n");} case 3: {print(" Carrots are selected\n");} case 4: {print(" Squash is selected\n");} } i++; temp = nthargf(option,i); } print("\n"); # status line 16 is the single-select scrolling menu with no default print("Single-select scrolling menu status:\n"); option = int(nthline(status,16)); switch (option) { case 1: {print(" Beef is selected\n\n");} case 2: {print(" Poultry is selected\n\n");} case 3: {print(" Fish is selected\n\n");} case 4: {print(" None is selected\n\n");} } # status line 17 is the multiple-select scrolling menu with default print("Multiple-select scrolling menu status:\n"); option = nthlinef(status,17); i = 1; temp = nthargf(option,i); while(temp) { switch (temp) { case 1: {print(" Cake is selected\n");} case 2: {print(" Pie is selected\n");} case 3: {print(" Ice Cream is selected\n");} case 4: {print(" Cookies are selected\n");} case 5: {print(" Candy is selected\n");} } i++; temp = nthargf(option,i); } print("\n"); # status line 18 is the username field content: print("Username:\n"); print(" ",nthline(status,18),"\n");
response()
4-305
# status line 19 is the password field content: print("Password field content:\n"); print(" ",nthline(status,19),"\n"); return; } function main() { psl_tm = asctime(time(),"%S\n%M\n%H\n%d\n%m\n%y\n%w\n%j"); seconds = trim(nthlinef(psl_tm,1),"\n"); minutes = trim(nthlinef(psl_tm,2),"\n"); hours = trim(nthlinef(psl_tm,3),"\n"); day = trim(nthlinef(psl_tm,4),"\n"); month = trim(nthlinef(psl_tm,5),"\n"); year = trim(nthlinef(psl_tm,6),"\n") + 1900; current = 3600 * hours + 60 * minutes + seconds; return_status = response( "Deans response() Example", -1, ["h=910","w=750","H=0","e=1","o=Accept","N=0","A=0","B=0"], # # # # The following are the dialog box control definitions. Those controls that return a value are identified by an asterisk preceding the label in the comment area on the right-hand side. # row: # column: # label # *check box # frame: # column: # *radio box # *radio box # *radio box # label # icon # *option menu # *popup: # column: # frame: # column: # label # *time spinner # frame: # column: # label # *option menu # # # # *slide bar # *text field # *toggle button # label # row: # *radio button # vertical separator # *radio button # label # row: # *scrolled list s,d # *scrolled list m,d
[15,3], [16,12], [1,"List Operator:"], [9,"Yes=0","No=0","Maybe=1"], [14,1], [16,3], [7,"Yes=0","No=0","Maybe=1"], [7,"Left=0","Center=1","Right=0"], [7,"More=0","Enough=0","Less=1"], [1,"The BMC Software logo follows:"], [19,"$PATROL_HOME/lib/images/BMC.xbm"], [10,"Time:",2,"Month","Day","Year","Hour","Minute"], [21,1,"Time Machine","Time Controls"], [16,4], [14,1], [16,2], [1,"Clock Controls"], [24,current], [14,1], [16,4], [1,"Calendar Controls"], [10,"month",month,"January","February", "March","April","May","June","July", "August","September","October", "November","December"], [2,"day",1,31,day], [12,"year",int(year)], [13,"Automatic Return in 1 Hour",1], [1,"Welcome to another time!"], [15,3], [6,"Unix=1","Windows NT=0","OS/2=0"], [5], [6,"Binary=0","Text=0","Autoselect=1"], [0,"Our Menu:"], [15,4], [17,"Water=1","Coffee=0","Tea=0","Wine=0"], [18,"Potatoes=1","Peas=1","Carrots=0","Squash=0"],
4-306
[22,"Beef","Poultry","Pork","Fish","None"], [23,"Cake","Pie","Ice Cream","Cookies","Candy"], [12,"Username:"," ","e=1"], [12,"Password:"," ","e=0"], [5], "16\n12", "1\nList Internal Representation:", "9\nYes=0\nNo=0\nMaybe=1", "14\n1", "16\n3", "7\nYes=0\nNo=0\nMaybe=1", "7\nLeft=0\nCenter=1\nRight=0", "7\nMore=0\nEnough=0\nLess=1", "1\nThe BMC Software logo follows:", "19\n$PATROL_HOME/lib/images/BMC.xbm", "10\nTime:\n2\nMonth\nDay\nYear\nHour\nMinute", "21\n1\nTime Machine\nTime Controls", "16\n4", "14\n1", "16\n2", "1\nClock Controls", "24\n" . current, "14\n1", "16\n4", "1\nCalendar Controls", "10\nmonth\n" . month . "\nJanuary\n" . "February\nMarch\nApril\nMay\nJune\n" . "July\nAugust\nSeptember\nOctober\n" . "November\nDecember", "2\nday\n1\n31\n" . day, "12\nyear\n" . int(year), "13\nAutomatic Return in 1 Hour\n1", "1\nWelcome to another time!", "15\n3", "6\nUnix=1\nWindows NT=0\nOS/2=0", "5", "6\nBinary=0\nText=0\nAutoselect=1", "0\nOur Menu:", "15\n4", "17\nWater=1\nCoffee=0\nTea=0\nWine=0", "18\nPotatoes=1\nPeas=1\nCarrots=0\nSquash=0", "22\nBeef\nPoultry\nPork\nFish\nNone", "23\nCake\nPie\nIce Cream\nCookies\nCandy", "12\nUsername:\n\ne=1", "12\nPassword:\n\ne=0" ); print("Analysis of response() return value:\n"); print("------------------------------------\n\n"); # status line 1 is the dialog close status print("Dialog close status:\n"); if (int(nthlinef(return_status,1)) == 1) { print(" Dialog closed with Accept button\n\n"); } else { print(" Dialog closed with Cancel button\n\n"); }
# # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # #
*scrolled list s,~d *scrolled list m,~d *text field (echo) *text field (blank) vertical separator column: label *check box frame: column: *radio box *radio box *radio box label icon *option menu *popup: column: frame: column: label *time spinner frame: column: label *option menu
*slide bar *text field *toggle button label row: *radio button vertical separator *radio button label row: *scrolled list s,d *scrolled list m,d *scrolled list s,~d *scrolled list m,~d *text field (echo) *text field (blank)
print("Analysis of response() dialog list operator fields:\n"); print("---------------------------------------------------\n\n"); list_op_status = nthlinef(return_status,"2-20"); response_analysis(list_op_status); print("\n"); print("Analysis of response() dialog list internal representation fields:\n");
BMC Software, Inc., Confidential and Proprietary Information
response()
4-307
Figure 4-1 shows the response() function dialog box displayed by the example program.
Figure 4-1
4-308
The following is a sample output from the response() function test program:
Analysis of response() return value: -----------------------------------Dialog close status: Dialog closed with Accept button Analysis of response() dialog list operator fields: --------------------------------------------------Check box status: Yes is checked Radio box frame status: Yes is selected Left is selected More is selected Option menu status: Month is selected Popup dialog close status: Popup was displayed and closed using Accept Time control settings: hours control is set to 5 minutes control is set to 42 seconds control is set to 22 month control is set to August day control is set to 17 year control is set to 1955 Automatic return toggle status: Automatic return in 1 hour is set Radio box status: Windows NT is selected Binary is selected Single-select scrolling menu status: Coffee is selected Multiple-select scrolling menu status: Peas are selected Squash is selected Single-select scrolling menu status: Beef is selected Multiple-select scrolling menu status: Cake is selected Pie is selected Username: dherr1 Password field content: pass1
response()
4-309
Analysis of response() dialog list internal representation fields: -----------------------------------------------------------------Check box status: No is checked Radio box frame status: Maybe is selected Right is selected Less is selected Option menu status: Year is selected Popup dialog close status: Popup was not displayed Time control settings: hours control is set to 9 minutes control is set to 2 seconds control is set to 22 month control is set to June day control is set to 19 year control is set to 1996 Automatic return toggle status: Automatic return in 1 hour is set Radio box status: Unix is selected Autoselect is selected Single-select scrolling menu status: Tea is selected Multiple-select scrolling menu status: Peas are selected Carrots are selected Single-select scrolling menu status: None is selected Multiple-select scrolling menu status: Cookies are selected Candy is selected Username: dherr2 Password field content: pass2
4-310
response_get_value()
Retrieve a return value from the elements of a dynamic response() function dialog box
Format
response_get_value(rid,polltype)
Parameters
Parameter rid Definition
The identifier of the response() function dialog box to which the response_get_value() function is directed. The response() function returns id instead of an element return value the first time it is executed with the D=1 preference specified. Flag that specifies the type of polling the response_get_value() function should use to acquire the return value of the dialog box identified by rid. Valid range: block the current PSL process and wait for the dialog box to return a value 1 poll the queue of return values from response() function dialog boxes and return the most recent return value that is queued for rid Default if not specified: 0 0
polltype
Description
The response_get_value() function retrieves the most recent return value for the response() function dialog box identified by rid. Depending on the value of polltype, the response_get_value() function will either block the current PSL process and wait for a return value or will poll a queue of return values and retrieve the most recent return value for rid.
response_get_value()
4-311
The response_get_value() function is required for the response() function dynamic mode because both the response( . . . "D=1" . . . ) function and the response(rid . . . ) function return operation status values and neither returns the state of the dialog box elements. The response_get_value() function sets the PSL errno variable as follows: Dialog is gone and no queued values are available:
errno = 84 E_PSL_RESPONSE_NO_VALUE
4-312
response_get_value()
4-313
rindex()
Return the last occurrence of one text string within another
Format
rindex("text","string")
Parameter
Parameter text Definition
Text to be examined for occurrences of string. The text can be a text string enclosed in double quotation marks, or one or more PSL commands that produce text as output. One or more characters whose last occurrence is being identified within text
string
Description
The rindex() function returns the position of the last occurrence of string in text or 0 if string does not occur in text. Positions in string are numbered starting from one and are indicated as integers.
4-314
Example
The following is an example of the rindex() function.
sentence = "The quick brown fox jumped over the lazy dogs"; findme = "he"; print("The last occurrence is in position ",rindex(sentence,findme));
rindex()
4-315
set()
Assign a value to a variable
Format
set(variable,value)
Parameters
Parameter variable Definition
The name of a variable in the PATROL Agent object hierarchy to which value is assigned The variable parameter is validated using the following rules:  variable is composed of name segments separated by a slash (/)  variable may start with a slash (/), but not end with a slash(/)  variable may not contain empty segments  variable may not contain unprintable characters  variable may not contain whitespace other than the space character  variable may contain spaces within a segment but not at the beginning or end of a segment
value
Description
The set() function sets the value of variable to be value. If variable is a relative name and does not exist in the context of the PSL script, the set() function successively searches each ancestors context until variable is found or until the search fails in the context of the computer. The set() function always returns the NULL string. However, if the variable parameter is not valid, the PSL runtime error 532, Badly formed object name. is generated.
BMC Software, Inc., Confidential and Proprietary Information
4-316
Example
The following PSL statement sets the value of RDB database Dev parameter MyParam to 10.
set("/RDB/Dev/MyParam/value",10);
set()
4-317
set_alarm_ranges()
Set the range for the alarm conditions for a particular application or parameter
Format
set_alarm_ranges(new_ranges,param,appl,param_oid,path)
Parameters
Parameter new_ranges Definition
A newline-separated list of alarm range settings. The first element of the list is the setting for the border alarm; the second element is for the first alarm zone (Alarm1); and the third element is for the second alarm zone (Alarm2). Each element of the list is of the form
active min max trigger max_occ state active = 1 or 0 indicating whether the alarm is active min = integer indicating the minimum of the zone max = integer indicating the maximum of the zone trigger = integer indicating how many times the
parameter value must be in the range before triggering. Valid range: 0 Immediately on alarm 1 After alarm has occurred n times 2 After all recovery actions fail max_occ = integer indicating the maximum number of times the alarm occurs state = 0(OK) or 1(WARN) or 2(ALARM) indicating what occurs
param appl
The name of the parameter that is to be monitored Either the name of the application (for example, FILESYSTEM) or the application instance objectid (for example, 88) Optional parameter objectid Optional path to the parameter
param_oid path
4-318
Description
The set_alarm_ranges() function sets the range for the alarm conditions for a particular application or parameter. Although param and appl are required, they can be "", if param_oid or path or both are supplied. Calls to the set_alarm_ranges() function that specify the param and appl parameters without the param_oid and path parameters set the alarm ranges for the parameter class and affect all parameter instances of that class. However, calls to the set_alarm_ranges() function that specify the param_oid and path parameters set the alarm ranges for that particular parameter instance and do not affect the alarm ranges for other instances of that class.
Return Value
The function returns the string "not found" if the parameter class cannot be found. Otherwise, it returns a number indicating which ranges were correctly set. The binary representation of the number should be considered. If the first bit is set, then the setting of the first range (border alarm range) failed. If the second bit is set, the setting of the Alarm1 range failed, and so on.
Note
The Consoles knowledge may not be a true reflection of the knowledge in the Agent if this function is used. The Consoles do gather alarm range information from the agent, but the Agent sends it only when a parameter is drilled down on. Therefore, if the Console has an open graph and the alarm ranges are subsequently changed by the set_alarm_ranges() function, then the range information displayed in the graph will not be updated until the graph is popped down and drilled into again.
set_alarm_ranges()
4-319
Example
The following is an example of the set_alarm_ranges() function.
new_ranges = "0 1 99 0 0 0\n0 80 90 0 0 0\n1 90 99 1 0 2"; result = set_alarm_ranges(new_ranges,"","","","/FILESYSTEM/root/FSCapacity);
The following example would only change the alarm ranges for "/FILESYSTEM/root/FSCapacity." Other FSCapacity parameter instances in the FILESYSTEM application would not be affected.
result = set_alarm_ranges(new_ranges,"","","","/FILESYSTEM/root/FSCapacity);
4-320
share()
Convert a local channel into a shared global channel
Format
share(channel,"name")
Parameters
Parameter channel Definition
Process I/O channel number that was returned when the channel was opened using the fopen() or popen() function Character string used to identify the shared channel in the table of global channels. BMC Software recommends that you specify a nonnumeric name to avoid conflicts with numbers used internally for local channels. Using a number for name does not actually cause the share() function to fail but will raise a PSL run-time warning. The share() function will dutifully place the specified numeric name in the global table, leading to potential conflicts with local channels in close(), read(), write(), and readln() functions.
name
Description
The share() function is the main function for using shared channels. The share() function propagates an existing local channel into the table of global channels as name. Channels opened by either the popen() or fopen() functions can be shared. If the share() function is successful, it returns 0. The local channel is no longer available in the process that opened it and does not require a close() function. In fact, the close() function will return an error since it will not find the local channel.
BMC Software, Inc., Confidential and Proprietary Information
share()
4-321
The share() function will fail, returning 1 and setting the PSL errno variable if the local channel does not exist the global channel name already exists in the global channel table
Upon failure, the local channel is unchanged and still available. No global channel is added. A global channel is referred to by name when passed to the read(), readln(), write(), and close() functions. These functions will first search the local channel table containing only channel numbers and then the global channel table.
The share() function and the Knowledge Module Developer
The PATROL Agent performs no explicit cleanup of the shared channels. It is up to the Knowledge Module developer to clean up as well as possible. Unfortunately, there is no easy way to intercept a console request to deactivate an application or parameter and hence doing so for an application using shared channels will most likely not terminate the external process. For a brute-force cleanup, it is possible to use close(name,3) to remove a global channel and terminate its external process. It is also possible to write a cleanup all shared channels menu command using the get_chan_info() function to return a list of shared channels and close() to remove them.
Example
The following PSL script uses the share() function to convert a local channel into a shared global channel.
chan = fopen("/etc/passwd"."r"); share(chan,"passwd_handle"); # read from the global channel while ((user = readln("passwd_handle")) != EOF) { printf("%s\n",user); }
BMC Software, Inc., Confidential and Proprietary Information
4-322
sin()
Return the sine of the argument
Format
sin(radians)
Parameter
Parameter radians Definition
Arc length in radians whose sine is to be determined Valid range:   radians  
Description
The sin() function returns the sine of radians. The output range for the sin() function is 1  sin()  1.
Example
The following example prints a table of the sin() function in the range 0 to 2 in increments of 30 degrees (instead of radians).
function main() { PI = 3.141593; print("SINE FUNCTION TEST\n\n"); print(" degrees calculated expected print(" ------- ---------- --------
# use a PSL list to hold the expected values (The printf # statement will evaluate the elements containing sqrt # expressions) expected = [ 0,0.5,0.5 * sqrt(3), 1,0.5 * sqrt(3),0.5, 0,-0.5,-0.5 * sqrt(3), -1,-0.5 * sqrt(3),0.5,0 ]; # Use a PSL List to hold the exact value strings
BMC Software, Inc., Confidential and Proprietary Information
sin()
4-323
exact = [ " 0"," 0.5"," 0.5 * sqrt(3)", " 1"," 0.5 * sqrt(3)"," 0.5", " 0","-0.5","-0.5 * sqrt(3)", "-1","-0.5 * sqrt(3)","-0.5"," 0" ]; increment = 0; while (increment <= 360) { printf( " %3d %8.5f %8.5f %s\n", increment, sin(2 * PI * increment / 360), trim(nthline(expected,int(1 + increment / 30)),"\n"), trim(nthline(exact,int(1 + increment / 30)),"\n") ); increment += 30; } return; }
4-324
sinh()
Return the hyperbolic sine of the argument
Format
sinh(argument)
Parameter
Parameter argument Definition
Numeric value whose hyperbolic sine is to be determined Valid range:   argument  
Description
The sinh() function returns the hyperbolic sine of argument. The hyperbolic sine is defined by the expression:
sinh(x)
= (ex ex)/2
where e is the base for the natural logarithms (e =2.71828 . . .). The output range for the sinh() function is sinh() .
Example
The following PSL script uses the sinh() function to verify the hyperbolic function power identity sinh2 x = 0.5(cosh 2x  1)
sinh()
4-325
function main() { print("HYPERBOLIC SINE TEST\n\n"); print(" value sinh(x) pow(sinh(x),2) print(" ----- --------- -------------count = -2; while (count <= 2) { printf( " %+3d %+9.5f %+9.5f count, result = sinh(count), pow(result,2), 0.5 * (cosh(2 * count) - 1) ); count += 0.1; } return; }
%+9.5f\n",
4-326
sleep()
Suspend process execution for a number of seconds
Format
sleep(seconds)
Parameter
Parameter seconds Definition
Integer specifying the number of seconds the process should be suspended. Valid range:  seconds > 0 is the number of seconds the process will sleep  seconds  0 the timer expires immediately
Description
The sleep() function suspends a PSL process for the specified number of seconds. While suspended, the PSL process consumes no CPU resources and is not interpreted until awakened by the expiration of the seconds timer.
Note
The sleep() function only suspends the process that calls it. All other PSL processes continue normal execution. The sleep() function returns a run-time warning if seconds is nonnumeric, in which case the timer defaults to zero.
sleep()
4-327
Example
The following is an example of the sleep() function.
print("Hello world!\n"); sleep(10); print("Good-bye world!\n");
4-328
snmp_agent_config()
Indicate if the PATROL SNMP Sub-Agent is active or not active
Format
snmp_agent_config()
Description
The snmp_agent_config() function returns one of the following messages indicating if the PATROL SNMP Sub-Agent is active or inactive.
SNMP support is not active.
or
SNMP support is active.
snmp_agent_config()
4-329
Example
The following example uses the snmp_agent_config() function to create a user-defined function, verify_snmp_agent(), to check for SNMP support. The main() section of the example starts SNMP, checks for SNMP support, stops SNMP, and then checks again for SNMP support using the user-defined verify_snmp_agent() function:
function verify_snmp_agent() { print("Checking for SNMP support... "); #Check the result of snmp_agent_config()function for the text "not" starting in the 17th #character of the output string using the substr() fubction. if (substr(snmp_agent_config(),17,3)=="not") { print("SNMP NOT ACTIVE\n"); } else { print("SNMP ACTIVE\n"); } return; } function main() { print("Starting SNMP\n"); snmp_agent_start(); #Starting SNMP verify_snmp_agent(); #Checking for SNMP support print("Stopping SNMP\n"); snmp_agent_stop(); #Stopping SNMP verify_snmp_agent(); #Checking for SNMP support }
4-330
snmp_agent_start()
Start the PATROL SNMP Sub-Agent
Format
snmp_agent_start()
Description
The snmp_agent_start() function starts the PATROL SNMP Sub-Agent listening for SNMP requests. If the snmp_agent_start() function is issued and the PATROL SNMP Sub-Agent is already running, the snmp_agent_start() function has no effect. The snmp_agent_start() function returns the string OK if successful, or the string ERR if an SNMP master agent is not running.
Example
The following example checks the output from snmp_agent_config() function for the text "SNMP support is not active." If the text is found, SNMP support is not active, and the snmp_agent_start() function is used to start the PATROL SNMP Sub-Agent. The return value of of the snmp_agent_start() function is checked for the string "OK" to verify that the PATROL SNMP Sub-Agent started.
if (grep("SNMP support is not active.",snmp_agent_config())) { if (snmp_agent_start() == "OK") { print("Patrol SNMP sub-agent started.\n"); } else { print("Patrol SNMP sub-agent failed to start.\n"); print("Make sure the SNMP Master Agent is running.\n"); } }
BMC Software, Inc., Confidential and Proprietary Information
snmp_agent_start()
4-331
snmp_agent_stop()
Stop the PATROL SNMP Sub-Agent
Format
snmp_agent_stop()
Description
The snmp_agent_stop() function stops the PATROL SNMP Sub-Agent if it was running or performs no action if it was not. The snmp_agent_stop() function returns the string OK if it stops the PATROL SNMP Sub-Agent or finds it not running.
Example
The following example checks the output from snmp_agent_config() function for the text "not" starting in the 17th position. If the text "not" is not found, SNMP support is active, and the snmp_agent_stop() function is used to stop the PATROL SNMP Sub-Agent.
if (substr(snmp_agent_config(),17,3)!="not") { snmp_agent_stop(); print("Patrol SNMP sub-agent stopped\n"); }
4-332
snmp_close()
Close a PATROL Agent SNMP session
Format
snmp_close("session")
Parameter
Parameter session Definition
ID of the SNMP session that is to be closed. The session is the value returned when an snmp_open() function is executed.
Description
The snmp_close() function closes session with the PATROL SNMP Sub-Agent that was opened with the snmp_open() function and removes internal structures belonging to session. The snmp_close() function sets the PSL variable errno = 93 (E_PSL_NO_SUCH_ID) if session is not a valid SNMP session ID. The snmp_close() function returns the string OK if successful, or the NULL string otherwise.
snmp_close()
4-333
Example
The following example opens an SNMP session makes a query to determine what SNMP agent is listening on port 1161 and closes the SNMP session:
session=snmp_open(runner,,,,,1161); print(snmp_get(session,.1.3.6.1.2.1.1.1.0)); snmp_close(session);
4-334
snmp_config()
Return the default parameters for one or more open PATROL SNMP sessions that were opened with the snmp_open() function
Format
Return a list of all open PATROL SNMP sessions separated by new-line characters: snmp_config() Return the default parameters for session separated by spaces: snmp_config("session") Set the default parameters for the session: snmp_config("session","community",timeout,retries)
Parameters
Parameter session Definition
ID of the SNMP session whose default parameters are to be returned or set. The session is the ID returned when an snmp_open() function is executed. Character string used as a community string for SNMP operations Default if not specified: no change to exiting community
community
timeout
Integer value of the session timeout parameter in milliseconds (ms) Default if not specified: no change to exiting timeout
retries
Integer value indicating the number of retries to attempt when a timeout occurs Default if not specified: no change to exiting retries
snmp_config()
4-335
Description
The snmp_config() function has three different formats that perform three distinct actions:  The format snmp_config() returns a list of all open SNMP session separated by new-line characters. If no sessions are open the NULL string is returned. The following is an example of the snmp_config() function output for three active sessions: sess1 sess2 sess3  The format snmp_config(session) returns a string of the default parameters for session separated by spaces. The output string for each session is as follows:
host community timeout retries Value host community timeout retries Definition
TCP/IP address of the computer system to which the session is opened Name of community string used for SNMP operations Session timeout value in milliseconds (ms) Number of retries to attempt when a timeout occurs
The format snmp_config(session,community,timeout,retries) sets the default parameters of session to the indicated values. If any parameter is specified in the snmp_config() function as the NULL string "", the existing default value for the parameter is unchanged. Returns the string OK if successful or set the errno variable to 93 indicating a bad session id.
4-336
Example
The following PSL script includes each of the three uses of the snmp_config() function (to list existing sessions, to list session settings, and to set session settings):
# Open three snmp sessions snmp_sessiona = snmp_open("runner","","","","",""); snmp_sessionb = snmp_open("gsmithisdn","","","1000","6","161"); snmp_sessionc = snmp_open("gsmith","","","","","1161"); # Print session id for each of the sessions print("snmp_sessiona: ".snmp_sessiona."\n"); print("snmp_sessionb: ".snmp_sessionb."\n"); print("snmp_sessionc: ".snmp_sessionc."\n"); print("\n"); # Capture and print list of open snmp sessions ignoring blank lines sessions = grep("^$",snmp_config(),"v"); print("Output from snmp_config():\n".sessions."\n"); print("Number of open sessions: ".lines(sessions)."\n"); print("\n"); # Loop through list of open snmp sessions and print snmp_config for each foreach session (sessions) { print("Output from snmp_config for ".session.": ".snmp_config(session)."\n"); } print("\n"); # Change default snmp session parameters for sessiona. # and retries to 5. Change timeout to 700
print("Use snmp_config() to change default parameters for ".snmp_sessiona.": "); print(snmp_config(snmp_sessiona,"",800,5)."\n"); # Change default snmp session parameters for sessionb. # "internal", timeout to 600, and retries to 7. Change community to
print("Use snmp_config() to change default parameters for ".snmp_sessionb.": "); print(snmp_config(snmp_sessionb,"internal",600,7)."\n"); print("\n"); # Loop through list of open snmp sessions and print snmp_config for each # then close the snmp session. foreach session (sessions) { print("Output from snmp_config for ".session.": ".snmp_config(session)."\n"); snmp_close(session); }
snmp_config()
4-337
4-338
_snmp_debug()
Activate SNMP debugging features
Format
_snmp_debug(flags)
Parameter
Parameter flags Definition
Binary flags that activate PSL SNMP debugging features. Valid range: 0 1 2 3 Deactivate debug reporting. Dump all input/output packets to the PATROL computer console display window. Provide additional information about timeout errors. Both ranges 1 and 2 apply.
Description
The _snmp_debug() function enables the basic SNMP debugging function within PSL. The _snmp_debug() function returns the previous flags value or NULL indicating that the new flags resulted in an error condition.
_snmp_debug()
4-339
Example
The following is an example of the _snmp_debug() function:
switch (debug_level) { # dump I/O packets to PATROL computer console window case 1: {new_level = _snmp_debug(1);} # provide additional timeout error info case 2: {new_level = _snmp_debug(2);} # both levels 1 and 2 case 3: {new_ level = _snmp_debug(3);} }
4-340
snmp_get()
Request SNMP variables from the PATROL SNMP Management Information Base (MIB) on the agent that the SNMP session is opened with
Format
snmp_get("session","variable1, . . . ,variablen")
Parameters
Parameter session Definition
ID of the SNMP session to which the SNMP get-request command is submitted. The session is the ID returned when an snmp_open() function is executed. Name of an SNMP MIB variable. The variablen can be specified in numeric form or in symbolic form if the MIB is known to the PATROL Agent. One variable name is required; additional variable names are optional.
variablen
Description
The snmp_get() function sends an SNMP get-request command to session to retrieve the values of variable1, . . . variablen from the SNMP Management Information Base (MIB). The snmp_get() function returns a space-separated list of the variables or the NULL string if an error occurs. The snmp_get() function can set the PSL errno value to either of the following:  
E_PSL_TIMEOUT if a timeout occurs during the request E_PSL_SNMP_ERROR if an error is returned in the response packet
snmp_get()
4-341
Output Format
The output of the snmp_get() function is a s list of SNMP variables in the following format:
name type length value Field name type length value Definition
Name of an SNMP MIB variable Character string indicating the name type Length of value Value of name
Example
The following PSL script uses the snmp_get() function to return a value from the PATROL SNMP MIB:
session = snmp_open("runner","","","","",""); value = snmp_get(session,".1.3.6.1.4.1.1031.1.1.1.6.1.1.0"); if (errno == 0) { print("snmp_get() for PatrolAgent <platform>.km:\n"); print(value); } else { print("snmp_get() failed... errno = ".errno.".\n"); } snmp_close(session);
HP
4-342
snmp_get_next()
Return variables from the SNMP Management Information Base (MIB) that are lexicographically next to the specified variable names on the agent that the SNMP session is opened with
Format
snmp_get_next("session","variable1, . . . ,variablen")
Parameters
Parameter session Definition
ID of the SNMP session to which the SNMP get-next-request is submitted. The session is the ID returned when an snmp_open() function is executed. Variable name that is to receive a value from the SNMP MIB for session. The string variablen is used to find the variable in the MIB whose name is the nearest alphabetically greater name than variablen. The value of that variable is returned. One variable name is required; additional variable names are optional.
variablen
Description
The snmp_get_next() sends an SNMP get-next-request to session to retrieve the value of the Management Information Base (MIB) variable whose name is lexicographically next to the name variablen. The snmp_get_next() function returns a space-separated list of the variables and their MIB names or the NULL string if an error occurs. The snmp_get_next() function can set the PSL errno value as follows: 
E_PSL_TIMEOUT if a timeout occurs during the request
snmp_get_next()
4-343
E_PSL_SNMP_ERROR if an error is returned in the response packet from the SNMP session
Output Format
The output of the snmp_get_next() function is a s list of SNMP variables in the following format:
name type length value Field name type length value Definition
Name of an SNMP MIB variable Character string indicating the name type Length of value Value of name
Example
The following example uses the snmp_get_next() function to retrieve and print all the application instances in the PATROL MIB. The application instance names can also be retrieved (much more easily) using the snmp_walk() function (see snmp_walk() on page 4-373).
function main() { local myhost,session,app_start,MIB_entry,address; myhost = get("/hostname"); session = snmp_open(myhost,"1","","","",1161); app_start = ".1.3.6.1.4.1.1031.1.1.1.7.1.1"; MIB_entry = trim(snmp_get_next(session,app_start),"\n"); address = nthargf(MIB_entry,1," "); while (nthargf(MIB_entry,14,".") == "applInstName") { printf("%s\n",MIB_entry); MIB_entry = trim(snmp_get_next(session,address),"\n"); address = nthargf(MIB_entry,1," "); } printf("\n"); snmp_close(session); return; }
BMC Software, Inc., Confidential and Proprietary Information
4-344
snmp_h_get()
Return variables from the PATROL SNMP Management Information Base (MIB) using a brief (local) session and default parameters from a specified agent
Format
snmp_h_get("host",variable1, . . . ,variablen)
Parameters
Parameter host Definition
Name of the computer to which the SNMP get-request is submitted. The host must be a name known to the local computer in the /etc/hosts file, the Domain Name System (DNS), the Network Information Service (NIS), or an IP address. Name of an SNMP MIB variable. The variablen can be specified in numeric form or in symbolic form if the MIB is known to the PATROL Agent. One variable name is required; additional variable names are optional.
variablen
Description
The snmp_h_get() function is the equivalent of the following series of PSL function calls:
session = snmp_open(host); snmp_get(session,variable1,variable2, . . . ,variablen); snmp_close(session);
snmp_h_get()
4-345
The snmp_h_get() function does the following: 1. opens an SNMP session on host. (Refer to the snmp_open() function description on page 4-354 for the default parameters used to open the session.) 2. sends an SNMP get-request command to the session to retrieve the values of variable1, . . . variablen from the SNMP Management Information Base (MIB) 3. closes the SNMP session The snmp_h_get() function returns a space-separated list of the variables or the NULL string if an error occurs. The snmp_h_get() function can set the PSL errno value as follows:  
E_PSL_TIMEOUT if a timeout occurs during the request E_PSL_SNMP_ERROR if an error is returned in the response packet
The output of the snmp_h_get() function is a s list of SNMP variables in the following format:
name type length value Field name type length value Definition
Name of an SNMP MIB variable Character string indicating the name type Length of value Value of name
4-346
Example
The following example uses the snmp_h_get() function to retrieve the first application instance name from the PATROL MIB:
function main() { local myhost,param_start; myhost = get("/hostname"); param_start = ".1.3.6.1.4.1.1031.1.1.1.6.1.1.0"; printf("%s\n",trim(snmp_h_get(myhost,param_start),"\n")); return; }
snmp_h_get()
4-347
snmp_h_get_next()
Return variables from the PATROL SNMP Management Information Base (MIB) that are lexicographically next to the specified variable names using a brief (local) session and default parameters
Format
snmp_h_get_next("host",variable1, . . . ,variablen)
Parameters
Parameter host Definition
Name of the computer to which the SNMP get-next-request will be submitted. The host must be a name known to the local computer in the /etc/hosts file, the Domain Name System (DNS), the Network Information Service (NIS), or an IP address. Variable name which is to receive a value from the SNMP MIB for session. The string variablen is used to find the variable in the MIB whose name is the nearest alphabetically greater name than variablen. The value of that variable is returned. One variable name is required; additional variable names are optional.
variablen
Description
The snmp_h_get_next() function is the equivalent of the following series of PSL function calls:
session = snmp_open(host); snmp_get_next(session,variable1,variable2, . . . ,variablen); snmp_close(session);
4-348
The snmp_h_get_next() function does the following: 1. opens an SNMP session on host. (Refer to the snmp_open() function description on page 4-354 for the default parameters used to open the session.) 2. sends an SNMP get-next-request command to the session to retrieve the value of the Management Information Base (MIB) variable whose name is lexicographically next to the name variablen 3. closes the SNMP session The snmp_h_get_next() function returns a space-separated list of the variables and their MIB names or the NULL string if an error occurs. The snmp_h_get_next() function can set the PSL errno value as follows:  
E_PSL_TIMEOUT if a timeout occurs during the request E_PSL_SNMP_ERROR if an error is returned in the response packet
The output of the snmp_h_get_next() function is a s list of SNMP variables in the following format:
name type length value Field name type length value Definition
Name of an SNMP MIB variable Character string indicating the name type Length of value Value of name
snmp_h_get_next()
4-349
Example
The following example uses the snmp_h_get_next() function to retrieve the second application instance name from the PATROL MIB:
function main() { local myhost,param; myhost = get("/hostname"); param = ".1.3.6.1.4.1.1031.1.1.1.6.1.1.0"; printf("%s\n",trim(snmp_h_get_next(myhost,param),"\n")); return; }
4-350
snmp_h_set()
Open a brief PATROL SNMP session with default parameters to set variables in the SNMP Management Information Base (MIB)
Format
snmp_h_set("host","objectid1 type1 value1", . . . , "objectidn typen valuen")
Parameters
Parameter host Definition
Name of the computer to which the SNMP set-request will be submitted. The host must be a name known to the local computer in the /etc/hosts file, the Domain Name System (DNS), the Network Information Service (NIS), or an IP address. Character string SNMP object identifier for the variable whose value is to be changed Character string indicating the objectidn type. Valid types are integer or string. Value to be assigned to objectidn
Description
The snmp_h_set() function is the equivalent of the following series of PSL function calls:
session = snmp_open(host); snmp_set(session,"objectid1 type1 value1", . . . ,"objectidn typen valuen"); snmp_close(session);
snmp_h_set()
4-351
The snmp_h_set() function does the following: 1. opens an SNMP session on host. (See the snmp_open() function on page 4-354 for the default parameters used to open the session.) 2. sends an SNMP set-request to the session to set specified variables in the Management Information Base (MIB) 3. closes the SNMP session The three parts of the snmp_h_set() function variable replacement, objectidn, typen, and valuen must be separated by spaces.
Return Values
The snmp_h_set() function returns the new value of the MIB variable, or when an error occurs, the NULL string or an error message.
MIB variable value
The snmp_h_set() function returns the new value of an SNMP MIB variable in the following format:
name type length value Field name type length value Definition
Name of an SNMP MIB variable Character string indicating the name type Length of the value Value of name
4-352
errno variable
When the snmp_h_set() function fails to set the PATROL SNMP MIB variable it can return the NULL and set the PSL errno value as follows:   
E_PSL_TIMEOUT if a timeout occurs during the request E_PSL_SNMP_ERROR if an error is returned in the response packet
error message
When the snmp_h_set() function fails to set the PATROL SNMP MIB variable because of an invalid objectid the following message is returned:
There is no such variable name in this MIB.
Example
The following example uses the snmp_h_set() function to set a value in the PATROL MIB:
if (snmp_h_get(myhost,MIBaddr)) { snmp_h_set(myhost,MIBaddr . " " . newtype . " " . newvalue); }
snmp_h_set()
4-353
snmp_open()
Open a PATROL Agent SNMP session with a PATROL Agent
Format
snmp_open("host","version","community",timeout,retries,port)
Parameters
Parameter host Definition
Name of the computer to which to open a session with the SNMP agent. The host must be a name known to the local computer in the /etc/hosts file, the Domain Name System (DNS), the Network Information Service (NIS), or an IP address. SNMP version. Valid range: 1 (this function does not currently support SNMP Version 2) Name of the character string used as a community string for SNMP operations Default if not specified: The value of "/snmp/default_r_community" or public
version community
timeout
Integer value of the session timeout parameter in milliseconds (ms) Default if not specified: 500 ms (0.5 second)
retries
Integer value indicating the number of retries to attempt when a timeout occurs Default if not specified: 3
port
User Datagram Protocol (UDP) port number on which to open the SNMP session Default if not specified: 1161
4-354
Description
The snmp_open() function opens a session to the SNMP agent on host using User Datagram Protocol port, specifying the indicated session parameters. The snmp_open() function returns the session id if successful and the NULL string if unsuccessful. The session ID consists of the characters sess followed by a numeric value as follows:
sess1
The snmp_open() function does not verify that it can reach the host or that an SNMP agent exists on hostit just creates its internal data structure with the parameters to be used in SNMP transactions. All sessions to an SNMP agent share a single socket opened by the first snmp_open() function call and closed by the last snmp_close() function call. The snmp_open function sets the PSL errno variable to E_PSL_SOCKET_BUSY if the call is the first call to open a session and the socket cannot be opened. The condition may indicate that the SNMP agent has no more available file descriptors.
Example
The following PSL script presents a common way to open a session with the PATROL SNMP Agent service on your local machine:
myhost = get("/hostname"); session = snmp_open(myhost,"","","","",1161);
snmp_open()
4-355
snmp_set()
Set variables in the PATROL SNMP Management Information Base (MIB)
Format
snmp_set("session","objectid1 lengthn type1 value1", . . . , "objectidn typen valuen")
Parameters
Parameter session Definition
ID of the SNMP session to which the SNMP set-request is submitted. The session is the ID returned when an snmp_open() function is executed. Character string SNMP object identifier for the variable whose value is to be changed Optional integer used for typen = character to indicate the length of the character string. This parameter is provided to support multiline strings. WARNING: The snmp_set() function will return an error if the text string valuen is not greater than or equal to lengthn characters.
objectidn lengthn
typen valuen
Character string indicating the objectidn type. Valid types are integer or string. Value to be assigned to the MIB variable objectidn
4-356
Description
The snmp_set() function sends an SNMP set-request to session to set specified variables in the Management Information Base (MIB). The snmp_set() function requires that the SNMP session community property be "private." The community property is set when the SNMP session is opened with the snmp_open() function. The three parts of the snmp_set() function variable replacement, objectidn, typen, and valuen must be separated by spaces.
Return Values
The snmp_set() function returns the new value of the MIB variable, or when an error occurs, the NULL string or an error message.
MIB variable value
The snmp_set() function returns the new value of an SNMP MIB variable in the following format:
name type length value Field name type length value Definition
Name of an SNMP MIB variable Character string indicating the name type Length of the value Value of name
snmp_set()
4-357
errno variable
When the snmp_h_set() function fails to set the PATROL SNMP MIB variable it can return the NULL and set the PSL errno value as follows:   
E_PSL_TIMEOUT if a timeout occurs during the request E_PSL_SNMP_ERROR if an error is returned in the response packet
error message
When the snmp_set() function fails to set the PATROL SNMP MIB variable because of an invalid objectid, length, or type, one of the following messages is returned:
There is no such variable name in this MIB. The value given has the wrong type or length.
Example
The following snmp_set() function will set the SNMP variable .1.3.4.6.4.1.0 to the string some_text_is_25\nchar_long:
snmp_set(sess,".1.3.4.6.4.1.0 25 string some_text_is_25\nchar_long");
4-358
snmp_trap_ignore()
Stop accumulating incoming PATROL SNMP event traps
Format
snmp_trap_ignore()
Description
The snmp_trap_ignore() function ends the accumulation of incoming SNMP event traps by interrupting any active snmp_trap_receive() function and closing the socket for event-trapping that was opened with the snmp_trap_listen() function. The snmp_trap_ignore() function returns the character string OK if successful or the NULL string otherwise.
Example
The following PSL statements cause the PATROL SNMP Agent service to ignore incoming traps.
opstatus = snmp_trap_ignore(); if (opstatus == "") { # snmp_trap_ignore() was bad! # diagnosis and recovery statements here }
snmp_trap_ignore()
4-359
snmp_trap_listen()
Start accumulating incoming PATROL SNMP event traps
Format
snmp_trap_listen()
Description
The snmp_trap_listen() opens a socket to accumulate incoming event traps to the SNMP agent. The socket number is chosen as follows: 1. value of the "/snmp/trap_port" variable; or, 2. snmp-trap/udp service; or 3. 162 The snmp_trap_listen() function does not block the process from which it is called. The snmp_trap_listen() function returns the characters "OK" if it is successful and the NULL string if it is not. The snmp_trap_listen() function can also set the PSL errno variable as follows: 
E_PSL_SNMP_ALREADY_LISTENING if a socket is already active to
already in use.
4-360
Example
The following PSL script is uses the snmp_trap_ignore(), snmp_trap_listen(), and snmp_trap_receive() functions:
# Stop accumulating traps. snmp_trap_ignore(); # Start listening for (accumulating) traps ret = snmp_trap_listen(); if ( ret == "") { ret = "NULL"; } printf("Listen status = %s Errno = %s\n", ret, errno); print("Running...\n"); print("\n"); # Return the first accumulated trap in blocking mode. # has been received. Wait until a trap Clears any snmp_trap_listen().
res = snmp_trap_receive(); if(res == "") { print("No SNMP trap available...errno =".errno."\n"); } else { printf(res); } print("\n"); sleep(10); # snmp_trap_receive() in blocking mode. # Dont wait. Return the next snmp trap if one exists.
res = snmp_trap_receive(2); if(res == "") { print("No SNMP trap available...errno=".errno."\n"); } else { print("SNMP Trap received:\n"); printf(res); } # Stop accumulating SNMP traps. snmp_trap_ignore();
snmp_trap_listen()
4-361
Sample output when two SNMP traps are received. The first SNMP trap is the result of a manual SNMP trap sent using snmp_trap_send. The second SNMP trap is the result a parameter alarm:
Listen status = OK Errno = 0 Running... SNMP Trap received: 172.19.201.36 1.3.6.1.4.1.1031 1 3743142 1.3.6.1.4.1.1031.1 6 string test 1 1.3.6.1.4.1.1031.2 6 string test 2 1.3.6.1.4.1.1031.2 6 string test 2 1.3.6.1.4.1.1031.2 6 string test 2 SNMP Trap received: 172.19.201.36 1.3.6.1.4.1.1031.1.1.2 5 3743929 1.3.6.1.4.1.1031.1.1.2.1.0 84 string Alarm #2 of global parameter mystate 1.3.6.1.4.1.1031.1.1.2.2.0 22 string /PSLCOM/PSLCOM/mystate 1.3.6.1.4.1.1031.1.1.2.3.0 0 string
Sample output when only one SNMP trap is received. The SNMP trap is the result of a parameter alarm.
Listen status = OK Errno = 0 Running... 172.19.201.36 1.3.6.1.4.1.1031.1.1.2 5 3782736 1.3.6.1.4.1.1031.1.1.2.1.0 87 stringAlarm #2 of global parameter MEMWCache 1.3.6.1.4.1.1031.1.1.2.2.0 24 string/MEMORY/MEMORY/MEMWCache 1.3.6.1.4.1.1031.1.1.2.3.0 0 string No SNMP trap available...errno=0
4-362
snmp_trap_raise_std_trap()
Raise the standard PATROL trap
Format
snmp_trap_raise_std_trap("text")
Parameter
Parameter text Definition
Character string that is to be included in the packet sent by the snmp_trap_raise_std_trap() function
Description
The snmp_trap_raise_std_trap() function sends the patrolTrapV1Raised trap with text in a packet to all entities registered with the piV1mTable. The piV1mTable is the table within the PATROL MIB that can be set by the external SNMP manager. The snmp_trap_raise_std_trap() function returns the characters "OK" if successful and the NULL string otherwise.
Example
The following is an example of the snmp_trap_raise_std_trap() function.
opstatus = snmp_trap_raise_std_trap(); if (opstatus != "OK") { # raise standard trap operation failed # diagnosis and recovery statements here }
snmp_trap_raise_std_trap()
4-363
snmp_trap_receive()
Return PATROL SNMP event traps
Format
snmp_trap_receive(flags)
Parameter
Parameter flags Definition
Binary flags that control the actions of the snmp_trap_receive() function. Valid range: 0 1 2 3 Neither ranges 1 nor 2 applies Print the trap information in a formatted output Dont block the current process waiting for an SNMP event trap (that is, poll for the trap) Both ranges 1 and 2 apply
Description
The snmp_trap_receive() function returns a formatted string containing information about the first accumulated trap (if any). Only one snmp_trap_receive() function may be active on a PATROL Agent. The snmp_trap_receive() function returns the NULL string and sets the PSL errno variable as follows: 
E_PSL_SNMP_NOT_LISTENING if there is no active socket established by a prior snmp_trap_listen() function E_PSL_SNMP_ALREADY_RECEIVING if there is already an active snmp_trap_receive() function active against the PATROL Agent
4-364
If the snmp_trap_receive() function is specified as blocking, it blocks the current process until one of the following occurs: A snmp_trap_ignore() function from another PSL process ends trapping. The socket established by the snmp_trap_listen() function receives an SNMP trap.
In the first case, the snmp_trap_listen() function returns the NULL string. In the second case, snmp_trap_listen() unblocks the current process and returns the trap.
Nonblocking snmp_trap_receive() Function
If the snmp_trap_receive() function is specified as nonblocking, it queries the socket established by the snmp_trap_listen() function and returns any trap waiting there or the NULL string indicating that no trap was waiting.
snmp_trap_receive()
4-365
The snmp_trap_receive() function returns a trap as a character string. The format of the return string depends on flags specified:  The default format for the string (flags = 0) is as follows: address enterprise subid uptime\n objectid1 type1 value1\n ... objectidn typen valuen\n  The format for the string when flags = 1 or 3 is as follows: address enterprise traptype subid uptime\n objectid1 type1 value1\n ... objectidn typen valuen\n The traptype is only returned when the flags parameter is set to 1 or 3.
Field address enterprise traptype Definition
Address of the SNMP agent that sent the trap The enterprise object identifier for the SNMP agent SNMP trap type as defined in RFC 1213 (Only returned when flags = 1 or 3.) Valid range: 0-5 standard traps 6 enterprise trap
subid uptime
Identifier number for the trap Number of clock ticks that the SNMP agent has been active. A clock tick is hardware-dependent and for Unix systems is typically between 10 and 20 milliseconds. Character string SNMP object identifier for the returned variable Character string indicating the objectidn type. Valid types are integer or string. Value of objectidn
4-366
Each return variable consisting of an objectidn, typen, and valuen triplet is separated by spaces and terminated by a newline character. This format is identical to the second snmp_trap_send() function format type. Output from the snmp_trap_receive() function can be piped to the snmp_trap_send() function without modification.
Example
The following is an example of the snmp_trap_receive() function:
myhost = get("/hostname"); if (index(snmp_trap_register_im("","list"),myhost) == 0) { # host not currently registered to receive traps opstatus = snmp_trap_register_im(myhost,"add"); if (opstatus != "OK") { # registration failed -- exit exit; } # at this point, it is OK to receive traps snmp_trap_receive(2); # 2 is non-blocking } else { snmp_trap_receive(2); # 2 is still non-blocking }
snmp_trap_receive()
4-367
snmp_trap_register_im()
Maintain a list of SNMP managers that receive PATROL SNMP traps
Format
snmp_trap_register_im("host/port/community","action")
Parameters
Parameter host Definition
Name of the computer whose SNMP manager will be added to or deleted from the list of SNMP managers that receive PATROL SNMP traps. The Universal Datagram Protocol (UDP) port number on which the SNMP agent socket opens. Default if not specified: 162
port
community
Name of the character string used as a community string for SNMP operations. Default if not specified: public
action
Character string identifying an action performed against "host/port/community" in the list of SNMP managers that receive PATROL SNMP traps. Valid range: list return the list of SNMP managers that receive SNMP traps add add "host/port/community" to the list of SNMP managers that receive PATROL SNMP traps delete remove "host/port/community" from the list of SNMP managers that receive PATROL SNMP traps Default if not specified: list
4-368
Description
The snmp_trap_register_im() function creates and maintains a list of SNMP V1 managers that receive PATROL SNMP traps. The list is stored in piV1mTable in the PATROL Management Information Base (MIB). The snmp_trap_register_im() function returns the following:   
OK string if successful for an add or delete operation the list of registered SNMP managers for the list operation the NULL string if an error occurs
The snmp_trap_register_im() function can also set the PSL variable errno = 96 (E_PSL_BAD_FUNCTION_PARAMETER) upon encountering a parameter error.
Examples
These examples show how to use the snmp_trap_register_im() function.
Return the List of SNMP Managers
Each of the following commands returns the list of registered SNMP managers:
snmp_trap_register_im(); snmp_trap_register_im("myhost","list");
The list action in the second line causes the PSL interpreter to ignore the myhost host name.
snmp_trap_register_im()
4-369
The following command adds the SNMP manager identified by myhost/162/public to the list of SNMP managers that receive PATROL SNMP traps:
snmp_trap_register_im("myhost","add");
The port 162 and community public are defaults and do not need to be specified in the command syntax.
Delete an SNMP Manager from the List
The following command will delete the SNMP manager identified by myhost/162/defaultcommunity from the list of SNMP managers that receive PATROL SNMP traps:
snmp_trap_register_im("myhost/162/defaultcommunity",delete);
4-370
snmp_trap_send()
Send a PATROL SNMP event trap
Format
snmp_trap_send("host/port/community","address enterprise traptype subid uptime","objectid1 type1 value1", . . . , "objectidn lengthn typen valuen")
Parameters
Parameter host Definition
Name of the computer to which the trap is sent. Refer to the /snmp/piV1m_list description in the PATROL Agent Reference Manual for more information. The Universal Datagram Protocol (UDP) port number to which the trap is sent on host. Name of the character string used as a community string for SNMP operations on host. Address of the SNMP agent that sent the trap The enterprise object identifier for the SNMP agent SNMP trap type as defined in RFC 1213. Valid range: 0-5 standard traps 6 enterprise trap
subid uptime
Identifier number for the trap Number of clock ticks that the SNMP agent has been active. A clock tick is hardware-dependent and for Unix systems is typically between 10 and 20 milliseconds. Character string SNMP object identifier for the included variable Number indicating the length of "valuen", if not delimited by \n Character string indicating the objectidn type. Valid types are integer or string. Value of objectidn
snmp_trap_send()
4-371
Description
The snmp_trap_send() function sends the specified trap to destination. If the snmp_trap_send() function returns the characters OK if it is successful and the NULL string otherwise. The snmp_trap_send() function also sets the PSL variable errno = 96 (E_PSL_BAD_FUNCTION_PARAMETER), or errno = 100 (E_PSL_SNMP_ERROR) and returns error messages to the computer icon console display window.
Example
The following is an example of the snmp_trap_send() function.
# Send SNMP trap to host on which PatrolAgent is running (i.e. localhost). host = get("/hostname"); tport = get("/snmp/trap_port"); arg1 = host."/".tport; arg2 = host." .1.3.6.1.4.1.1031 6 1 1"; print(snmp_trap_send(arg1,arg2, ".1.3.6.1.4.1.1031.1 string test", ".1.3.6.1.4.1.1031.2 string test 2", ".1.3.6.1.4.1.1031.3 string test 3", ".1.3.6.1.4.1.1031.4 string test 4"));
4-372
snmp_walk()
Return subsequent variables from the Management Information Base (MIB) on the agent that the SNMP session is opened with
Format
snmp_walk("session","variable")
Parameters
Parameter session Definition
ID of the SNMP session to which the series of SNMP get-next-request commands will be submitted. The session is the ID returned when an snmp_open() function is executed. Name of an SNMP MIB variable, which can be specified in numeric form or in symbolic form if the MIB is known to the PATROL Agent.
variable
Description
The snmp_walk() function returns all variables in the subtree for variable in the Management Information Base (MIB). The subtree for variable includes all variables of the form variable.argument_sequence where variable is the prefix name. The snmp_walk() function returns the NULL string if an error occurs and sets the PSL errno variable as follows:  
E_PSL_TIMEOUT if a timeout occurs during the request E_PSL_SNMP_ERROR if an error is returned in the response packet
snmp_walk()
4-373
Output Format
The output of the snmp_walk() function is a s list of SNMP variables in the following format:
name type length value Field name type length value Definition
Name of an SNMP MIB variable Character string indicating the name type Length of value Value of name
The timeticks, gauge, and counter variable types are followed by an extra new line character (\n). The extra new line character creates a blank line after these variable types in the snmp_walk() function output.
Example
The following example uses the snmp_walk() function to print all the application instances in the PATROL MIB. It is a more efficient form of a similar example using the snmp_get_next() function (see page 4-344).
function main() { local myhost,session,app_start; myhost = get("/hostname"); session = snmp_open(myhost,"1","","","",1161); app_start = ".1.3.6.1.4.1.1031.1.1.1.7.1.1"; printf("%s\n",snmp_walk(session,app_start)); snmp_close(session); return; }
4-374
sort()
Sort a list of numeric or alphabetic values
Format
sort(list,"mode",position)
Parameters
Parameter list mode Definition
PSL list whose elements that are to be sorted Optional character string specifying the sort order. Character string must be enclosed in double quotation marks. Valid Range: n nr "" r ascending numeric order descending numeric order ascending alphabetic order descending alphabetic order
position
Optional integer that specifies the character position within each element of list where sorting is to begin. The first character of each list element is character 1. If the length of every element within list is less than
position does not truncate elements; it only ignores the first (position  1) characters for purposes of
comparison. Default if not specified: 1
sort()
4-375
Description
The sort() function returns a sorted version of list that is ordered according to mode. The sort() function does not merge duplicate entries in list: the returned list has the same number of members as list. The order in which duplicates are returned is not defined because it is not defined for the C library qsort() function. This fact is relevant for the following cases:  numeric sorting of strings with identical numeric prefix values but different nonnumeric suffixes any sorting mode in which position is larger than more than one element within list (the sort() function regards all such elements as duplicate NULL elements)
If list is the NULL list, the sort function returns the NULL list. For a nonempty list, the sort() function always returns a well-defined list with the last line properly terminated by a new-line character.
Note list need not be terminated by a new-line character. Numeric sorting is
based on floating point values; nonnumeric list entries are converted according to the systems standard C library function atof().
4-376
Example
The following example shows the different sorting orders available in the sort() function.
function print_list(label,array) { printf("%s",label); foreach member (array) { printf("%2d ",trim(member,"\n")); } printf("\n"); } function main() { srandom(time()); i = 0; while (i <= 15) { list = [list,random(100)]; i++; } print_list("unsorted list print_list("sorted asc. numeric print_list("sorted desc. numeric print_list("sorted asc. alpha print_list("sorted desc. alpha }
: : : : :
sort()
4-377
sprintf()
Return the specified format as a character string to a destination
Format
sprintf(format)
Parameter
Parameter format Definition
Text, variable names, and control characters that specify the content and format of the character string output to the computer or task output window.
4-378
Parameter format
(continued)
Description
The sprintf() function is identical to the printf() function except that it returns the created string rather than outputting it to the PATROL Console. If there is an error in format, sprintf sets the PSL errno variable and returns the NULL string. The formats, conversions, and values of errno for the various errors are identical to those described for the printf() function. C programmers should be careful to use the PSL style:
destination=sprintf(format)
The latter style will often cause a compilation warning about a null-effect statement.
sprintf()
4-379
The sprintf() function does not support the C convention of using the asterisk (*) as a field width or precision indicator. The sprintf() function does not support the %p and %n conversion characters. The length modifiers h, l (ell), and L are not valid and are ignored by the sprintf() function. The sprintf() function format conversions are passed directly to the C library sprintf() routine on each platform. The output for obscure formatting features may differ across platforms, especially on platforms with libraries that do not conform to ANSI C requirements.
Conversion Differences between the C sprintf Routine and PSL sprintf Function
The format conversions have the same meaning between standard C and PSL, but the concept of variable types differs between the two. PSL supports only string types for its variables, and thus string arguments to the sprintf() function are converted in a manner appropriate for the format conversion:   Integral formats, such as %d, convert the string to signed integers. Noninteger numeric formats, such as %f, convert to floating point values.
%c prints the ASCII equivalent of its integer argument, or for
4-380
The sprintf() function provides one nonstandard C extensionthe %N conversion. The %N conversion preprocesses a numeric string so that commas separate each group of three digits beginning at the right side of the string. For example, the %N conversion causes the following conversions: 1234  1,234 12345  12,345 123456  123,456 The %N conversions ignores initial minus signs and blanks while searching for the first sequence of digits so that %N can be applied to negative values. If no digits are found after the skipped characters, the printed argument is unchanged. The %N conversion only modifies the first sequence of digits. For example, the %N conversion changes floating point numbers like 1234.1234 to become 1,234.1234 without changing to the digit sequence to the right of the decimal point. As part of the %N conversion, the sprintf() function performs a %s conversion using the field width and precision specifiers supplied in format. The sprintf() function prints the string resulting from the combined %N and %s conversions. Because of the embedded %s conversion, field width and precision under %N conversion have the same effect as with %s.
Note
Currently, no localization is supported by %N, and so the formatting achieved by %N does not change in different locales.
sprintf()
4-381
Example
The following PSL script uses the sprintf() statement to recursively build a formatted decimal/octal/hexadecimal conversion table before printing it.
function main() { i = 0; string = sprintf(" n Oct Hex\n"); string = sprintf("%s--- ---- ----\n",string); while (i++ <= 25) { string = sprintf("%s%3d %4o %4X\n",string,i,i,i); } print(string); return; }
4-382
sqrt()
Return the square root of the argument
Format
sqrt(argument)
Parameter
Parameter argument Definition
Numeric value whose mathematical square root is returned Valid range: 0  argument < 
Description
The sqrt() function returns the square root of the positive integer or real value argument.
sqrt()
4-383
Example
The following PSL script compares the output of the sqrt() function with that derived from the trigonometric identity ln(xa) = a ln(x) for the integers 1 through 10:
function main() { printf("SQUARE ROOT AND EXP(0.5 * LOGE) COMPARISON\n\n"); printf(" n sqrt(n) exp(0.5 * loge(n))\n"); printf(" -- ------- -----------------\n"); local i; i = 0; while (i++ <= 10) { printf(" %2d %7.5f %7.5f\n",i,sqrt(i),exp(0.5 * loge(i))); } }
4-384
srandom()
Initialize the random number generator with a seed value
Format
srandom(seed)
Parameter
Parameter seed Definition
Numeric value used as a starting point for pseudorandom number generation by the random() function
Description
The srandom() function sets the random number seed for the random() function. The seed is passed directly to the Unix C srandom() function. The PSL srandom() function always returns the NULL string.
Example
The following is an example of the srandom() function:
srandom(time()); i = 0; while (i++ <= 5) { printf("random number %1d is: %3d\n",i,random(100)); }
srandom()
4-385
subset()
Verify that one PSL list is a subset of another
Format
subset(set,subset)
Parameters
Parameter set subset Definition
PSL list that is the set in the set-subset verification PSL list that is the subset in the set-subset verification
Description
The subset() function returns a Boolean value of 0 or 1 indicating whether subset is a proper or improper subset of set. If subset is the NULL set, the subset() function returns 1 (TRUE). If set is the NULL set and subset is not, the subset() function returns 0 (FALSE). The subset() function ignores duplicates and returns 1 only if all elements of subset are also present in set.
4-386
Example
The subset() function can be used to determine whether a particular element is present in a set and thus provides is_member functionality such as the following:
if(subset(my_set,"blue")) { # PSL set "my_set" contains element "blue" }
It is not necessary to place a new line at the end of the blue string because it is inserted by the subset() function. The example statements are treated as a subset() function acting on a set with one element.
subset()
4-387
substr()
Return a specified portion of a string of characters
Format
substr("text",start,length)
Parameters
Parameter text Definition
Text from which a substring of characters is to be returned. The text can be a text string enclosed in double quotation marks, or one or more PSL commands that produce text as output. The character position within text that is to be the first character of the substring. The first character in text is character position 1. The total number of characters from text to be returned in the substring
start
length
Description
The substr() function returns the substring of text of length characters that starts at position start.
Example
The following is an example of the substr() function:
any_string = "The quick red fox jumped over the lazy brown dogs"; len - length(any_string); i = 0; while (i++ <= len) { printf("%s\n",substr(any_string,i,1)); }
4-388
system()
Submit a command to the computer operating system
Format
system("command","instance")
Parameters
Parameter command Definition
Syntax of the submitted operating system command. The command parameter can contain output redirection, pipes, wild cards, and so on. Optional application instance against which command executes Default: The application instance that is the nearest ancestor of command
instance
Description
The system() function returns any output to stdout/stderr produced by submitting command to the operating system. Unlike the execute() function, command is not executed directly but rather at the Unix command line:
sh -c command
Note
The shell used to execute command is the user login shell of the account where the system() function executes. For OS/2, the shell used to execute command is the shell specified in the COMSPEC environment variable.
system()
4-389
Sometimes it is desirable to submit long-running commands like daemons to run in the background. For more information on submitting commands to run in the background see the popen() function on page 4-201.
Example
The following is an example of the system() function.
if (get("/appType") == "NT") { printf("%s\n",system("net user")); } else { printf("%s\n",system("cat /etc/passwd")); }
4-390
tail()
Return the last lines from a text block
Format
tail("text",lines)
Parameters
Parameter text Definition
Text whose last lines are to be returned by tail(). The text can be a text string enclosed in double quotation marks, or one or more PSL commands that produce text as output. Number of lines of text to be returned, starting from the last line of text
lines
Description
The tail() function returns the last lines number of lines of text. It is equivalent to the Unix tail(1) command.
Note
The tail() function does not perform file I/O. If reading text from a file, you must use the cat() function for file I/O. For more information about the cat() function, see page 4-29.
tail()
4-391
Example
The following example uses the tail() function to return the last three lines from a PSL list:
psl_list = ["line01","line02","line03","line04","line05","line06","line07","line08"]; printf("%s\n",tail(psl_list,3));
4-392
tan()
Return the tangent of the argument
Format
tan(radians)
Parameter
Parameter radians Definition
Arc length in radians whose tangent is to be determined Valid range:   radians  
Description
The tan() function returns the tangent of radians. The output range for the tan() function is  < tan() < . The tan() function is undefined when radians = (2n+1)/2 where n is an integer.
Example
The following PSL script compares the output of the tan() function with the output of its trigonometric definition sin(x)/cos(x) and includes a test to bypass values of x such that cos(x) = 0:
function main() { PI = 3.141593; printf(" degrees tan(x) sin(x)/cos(x)\n"); printf(" ------- -------- -------------\n"); i = -10; while ((i += 10) <= 360) { radians = i * 2 * PI / 360; if (fabs(cosine = cos(radians)) <= 0.000001) { printf(" %3d*** tan(x) is undefined for this value\n",i); next; } printf(" %3d %+8.5f %+8.5f\n",i,tan(radians),sin(radians) / cosine); } }
tan()
4-393
4-394
tanh()
Return the hyperbolic tangent of the argument
Format
tanh(argument)
Parameter
Parameter argument Definition
Numeric value whose hyperbolic tangent is to be determined Valid range:   argument  
Description
The tanh() function returns the hyperbolic tangent of argument.The hyperbolic tangent is defined by the expression:
tanh(x)
where e is the base for the natural logarithms (e = 2.71828 . . .). The output range for the tanh() function is 1 tanh() 1.\
tanh()
4-395
Example
The following example verifies the output of the tanh() function against the output of its definition in the range -2  x  2:
function main() { printf("HYPERBOLIC TANGENT TEST\n\n"); printf(" x tan(x) definition\n"); printf(" ----- -------- ----------\n"); i = -2.1; while ((i += 0.1) <= 2.0) { eplusx = exp(i); eminusx = exp (-i); printf(" %+5.2f %+8.5f %+8.5f\n",i,tanh(i),(eplusx - eminusx) / (eplusx + eminusx)); } }
4-396
time()
Return the number of seconds since 00:00:00 GMT January 1, 1970
Format
time()
Description
The time() function returns the current time as the number of seconds that have elapsed since 00:00:00 GMT, Jan 01, 1970.
Example
The following is an example of the time() function:
function main() { local seconds,current; seconds = time(); current = asctime(seconds); printf("seconds since 00:00:00 GMT January 1, 1970 printf(" current date and time using asctime() printf(" current date and time using date() printf(" seconds using convert_date() }
: : : :
time()
4-397
tmpnam()
Return a unique name for temporary file creation
Format
tmpnam()
Description
The tmpnam() function returns a name that is guaranteed to be unique and can be used to pass to the fopen function for creating temporary files. The semantics of the tmpnam() function are similar to that of the C tmpnam() routinenotably, a restricted number of unique names are returned by the tmpnam() routine as defined by the C constant TMP_MAX. All PSL processes on a given PATROL Agent share the same set of names, and there can be a danger of mixing names. ANSI C guarantees that TMP_MAX is at least 25, but it is typically much larger than that. If the size of TMP_MAX is a concern, add a suffix to the returned file name.
Example
The following example shows how to use the tmpnam() function to generate a temporary file name. The PSL function adds a suffix to the returned name to further guarantee its uniqueness.
name = tmpnam() . ".dave"; fp = fopen(name, "w");
4-398
tolower()
Convert text to all lowercase characters
Format
tolower("text")
Parameter
Parameter text Definition
Text that is to be returned as lowercase letters. The text can be a text string enclosed in double quotation marks, or one or more PSL commands that produce text as output.
Description
The tolower() function returns a copy of text with all uppercase letters converted to lowercase letters.
Example
The following is an example of the tolower() function:
function main() { teststr = "SOME ARE UPPER, some are lower, SoMe ArE mIxEd"; printf(" original : %s\n",teststr); printf("all lower : %s\n",tolower(teststr)); }
tolower()
4-399
toupper()
Convert text to all uppercase characters
Format
toupper("text")
Parameter
Parameter text Definition
Text that is to be returned as uppercase letters. The text can be a text string enclosed in double quotation marks, or one or more PSL commands that produce text as output.
Description
The toupper() function returns a copy of text with all lowercase letters converted to uppercase letters.
Example
The following is an example of the toupper() function:
function example_20() { teststr = "SOME ARE UPPER, some are lower, SoMe ArE mIxEd"; printf(" original : %s\n",teststr); printf("all upper : %s\n",toupper(teststr)); }
4-400
trace_psl_process()
Enable PSL tracing for a specified application, parameter, or process
Format
trace_psl_process("what","name",value)
Parameters
Parameter what Definition
The PSL component of a KM that should have tracing enabled. This determines how the PTROL Agent will find name. Legal values are DISCOVERY, PREDISCOVERY, PARAMETER, and PID. Case is insignificant, and unique prefixes are allowed.
name value
The name of the application or parameter, or the PSL pid of the process The value to be set to the process (identified by what and name) PslDebug variable. Valid values: any value that PslDebug can be set to
Description
Use the trace_psl_process() function to enable PSL tracing for a specified application, parameter, or process. In previous releases, setting the PslDebug variable in the script was the only way to trace processes. The trace_psl_process() function provides a method to set the PslDebug variable for a particular process without having to put the assignment in the script text. The variable PslDebug is persistent across executions and is not reset when the process reinitializes. The function returns 1 if the call was successful and 0 if it was not. Usually, a return value of 0 means that the process could not be found.
trace_psl_process()
4-401
Examples
# Enable all tracing for the discovery process of the foo application status = trace_psl_process("DISC","foo",-1); # Disable all tracing for the pre-discovery process of the foo application status = trace_psl_process("PRE-DISC","foo",0); # Enable function argument tracing in foos foobar parameter for the # bar instance status = trace_psl_process("PARAM","/foo/bar/foobar",1024); # Enable variable assignment tracing and function argument tracing in # foos foobar parameter of the bar instance status = trace_psl_process("PARAM","/foo/bar/foobar",1024|4096); # Enable all tracing of the PSL process with the pid of 42 status = trace_psl_process("PID",42,-1);
4-402
trim()
Remove unwanted characters from text
Format
trim("text","unwanted")
Parameters
Parameter text Definition
Text to be returned without specified characters. The text can be a text string enclosed in double quotation marks, or one or more PSL commands that produce text as output. One or more characters that are to be removed from the copy of text output by the trim function.
unwanted
Description
The trim() function returns a copy of text with all occurrences of the characters in unwanted removed.
trim()
4-403
Example
The following is an example of the trim() function:
function main() { local sentence,trimmed_sentence; sentence = "Th$is \nlo^oks \nbet!ter \nwith \nunw*anted \nchar##acters \nremo@ved."; trimmed_sentence = trim(sentence,"\n$^!*#@"); printf("%s\n%s\n",sentence,trimmed_sentence); return; }
4-404
union()
Return a list that is the union of individual lists
Format
union(list1,list2,list3,list4 . . . listn)
Parameters
Parameter listn Definition
PSL list containing elements that shall be united and returned in a single well-defined list. Only the first two input lists, list1 and list2, are required; all others are optional.
Description
The union() function returns a PSL list that contains the elements from all listn merged together. Unlike the difference() and intersection() functions, the list returned by the union function is a well-defined set without any duplicates. The union(x,y) function is similar to specifying the unique(x.y) function using the string concatenation operator . to perform union() and the unique() function to remove duplicates. The advantage in using the union() function over the unique() function occurs when x has no terminating new-line character, in which case the use of the . operator could cause the last element of x and the first element of y to become treated as a single set element. The union() function adds a new line to the end of every nonempty list that is missing one. If the return value is not the NULL list, the returned set is always terminated by a new line so that all set elements end with a new-line character.
union()
4-405
Example
The following is an example of the union() function:
function main() { local group1,group2,group3,group4; group1 = [1,2,3]; group2 = [3,4,5]; group3 = [5,6,7]; group4 = [7,8,9,10]; printf("%s\n",union(group1,group2,group3,group4)); # or you can do it this way: printf("%s\n",union(group1,union(group2,union(group3,group4)))); return; }
Each of the two printf() function statements prints a PSL list containing the integers 1 through 10.
4-406
unique()
Remove the duplicate elements from a list
Format
unique(list)
Parameter
Parameter list Definition
PSL list containing elements that shall be returned in a single well-defined (unique) list
Description
The unique() function returns a well-defined PSL list with all duplicates removed. All elements that remain in the return value appear in the same order as they did in list. If list is the NULL list, the unique() function returns the NULL list; otherwise the unique() function returns a list that is terminated by a new-line character so that all list elements in the list end with a new-line character.
Example
The following is an example of the unique() function:
function main() { local list; list = [1,2,3,3,4,5,5,6,6,6,7,8,7,9,7,10]; printf("%s\n",unique(list)); return; }
The printf() function statement prints a PSL list containing the integers 1 through 10.
unique()
4-407
unlock()
Release a PSL process lock
Format
unlock("lockname")
Parameter
Parameter lockname Definition
Name of the lock that should be released
Description
The unlock() function releases lockname that was granted to this process by a previous call to the lock() function. The unlock() function returns 1 for success and 0 for failure. If no lock is named lockname or if it is not currently owned by this process, then the unlock() function reports a run-time error, sets the PSL errno variable, and returns 0.
Note
All locks held by a process are automatically released when the process exits in a manner similar to executing the unlock function. BMC Software recommends that you release locks explicitly using the unlock() function rather than implicitly using the process exit. If this process is the only one holding the lock and processes are queued for it, the first waiting process is awakened and granted use of the lock. If the first process is a shared request, then any other processes that are queued for a shared lock are also granted shared access to the lock (except for processes that are behind a writer request on the queue for this lock).
4-408
Example
The following is an example of the unlock() function:
if (unlock(PASSWD_LOCK)) { printf("lock released\n); } else { printf("lock release failed\n); }
unlock()
4-409
unset()
Remove a PATROL object that was previously assigned by the set() function
Format
unset("object")
Parameters
Parameter object Definition
Text string name of the PATROL object that is to be removed by the unset() function.
object must have been created by the set() function and the caller must have write permission to object.
Description
The unset() function removes the value of object that was previously assigned by the set() function. The unset() function always returns the NULL string and will set the PSL variable errno = 96 (E_PSL_BAD_FUNCTION_PARAMETER) if object is not found or if the caller does not have read permission to object.
4-410
va_arg()
Retrieve the next argument in a functions variable argument list
Note
The va_arg() function is used only within user-defined function() statements that specify a variable list of arguments in the function() definition.
Format
va_arg(va-list)
Parameters
Parameter va-list Definition
A PSL list containing a variable number of arguments.
Description
The va_arg() function returns the next argument from the variable-length list va-list. If there are no more arguments in va-list, the va_arg() function returns the NULL string and sets the PSL variable errno = 69 (E_PSL_ERANGE). When used with the va_start() function, the va_arg() can read a variable argument list multiple times, using the va_start() function to reset the list after each reading. (The va_start() function always resets the variable argument list to return the first argument.)
va_arg()
4-411
Example
The following is an example of the va_arg() function:
function summation(...) { c = sum = 0; terms = va_start(); c = va_arg(terms); while (c != "") { sum += c; c = va_arg(terms); } return sum; } function main() { print("Sum of the print("Sum of the print("Sum of the print("Sum of the print("Sum of the print("Sum of the print("Sum of the print("Sum of the return; }
2 3 4 5 6 7 8 9
is is is is is is is is
: : : : : : : :
4-412
va_start()
Reset a functions variable argument list to return the first argument
Note
The va_start() function is used only within user-defined function statements that specify a variable list of arguments in the function definition.
Syntax
va_start()
Description
The va_start() function resets a variable argument list within a user-defined function statement so that the next va_arg() function call will return the first of the variable arguments. The va_start() function may be called multiple times within a function statement; each time it will reset the variable argument list to return the first argument.
va_start()
4-413
Example
The following is an example of the va_start() function:
function reset_args(...) { term = va_start(); i = 0; while (i++ <= 3) { printf("argument %d is %d\n",i,va_arg(term)); } printf("variable arguments reset . . .\n"); term = va_start(); printf("reset argument is %d",va_arg(term)); return; } function main() { reset_args(100,110,120,130,140,150,160); return; }
4-414
write()
Write to a PSL process or file channel
Format
write(chan,"text")
Parameters
Parameter chan text Definition
Process I/O channel number to which text is written Text to be written to channel chan. The text can be a text string enclosed in double quotation marks, or one or more PSL commands that produce text as output.
Description
The write() function writes text to channel chan. The write() function returns the number of characters written or 1 on error. If text cannot be written immediately, the write() function call blocks until it can either write the whole of text or the channel terminates.
Note
The write() function can block for a process channel created using the popen() function but not for a file channel created using the fopen() function. To enforce serialization for shared channels, no two reader processes (that is, the read() or readln() functions) can be blocked on the same channel. The second reader process that attempts to block on the shared channel will fail, returning the NULL string and setting the PSL variable errno to E_PSL_BUSY_CHANNEL.
write()
4-415
Another possible shared channel failure can be caused by a close() function being executed against a channel that also has a blocked reader process.The close() function will cause the reader process to return the NULL string and set errno to E_PSL_UNBLOCKED_BY_CLOSE.
Example
The following PSL script uses the write() function to write to a disk file the table of decimal/octal/hexadecimal conversions that was created using the sprintf() function:
function main() { local channel,string; i = 0; channel = fopen("/local/convert.txt","w"); if (channel != "") { string = sprintf(" n Oct Hex\n"); string = sprintf("%s--- ---- ----\n",string); while (i++ <= 256) { string = sprintf("%s%3d %4o %4X\n",string,i,i,i); } write(channel,string); close(channel); } else { printf("File could not be opened, errno = %d",errno); } return; }
4-416
write_to_report()
Write arbitrary text to a popped-up task window
Format
write_to_report("handle","data")
Parameters
Parameter handle data Definition
The task ID returned by a call to the popup_report() function The text to be displayed in the task window
Description
The write_to_report() function writes arbitrary text to a task window that has been popped up on specified consoles. To pop up a task window, see the popup_report() function on page 4-203. The write_to_report() function returns one of the following values:   "1" if the write is successful "0" if the write fails
A write fails if all consoles have destroyed the task window thereby removing all the status information about the task. Thus, a subsequent call to popup_report() will pop up again the task window on the consoles.
Example
The following PSL script uses the write_to_report() function to write some text to a popped-up task window.
BMC Software, Inc., Confidential and Proprietary Information
write_to_report()
4-417
# Pop up a task window on all consoles that are monitoring the Foobar application handle = popup_report("My Title","Foobar","","First bit of text\n"); ok = 1; while (handle && ok) { sleep(10); # Pop up the task window on all consoles that have started monitoring the # Foobar application since the first call above (and previous call below) handle = popup_report("My Second title","Foobar",handle,"Second bit of text\n"); if (handle) { # the handle is still valid # Write some text to the task window write_to_report(handle,"hello world\n"); ok = write_to_report(handle,"goodbye world\n"); } }
4-418
5
5 5
PSL provides several commands external to the language that allow you to execute PSL commands from the operating system command line as well as compile and execute PSL programs. %DUMP List Specific Information. . . . . . . . . . . . . . . . . . . . . . . . 5-2 %DUMP CHANNELS List PSL Global Channels . . . . . . . . . . . . 5-3 %DUMP LIBRARIES List Loaded PSL Libraries . . . . . . . . . . . . 5-5 %PSL Execute a PSL Statement . . . . . . . . . . . . . . . . . . . . . . . . . . 5-6 %PSLPS List Current PSL Processes . . . . . . . . . . . . . . . . . . . . . . 5-7 psl PSL Compiler Command. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5-8
5-1
Format
%DUMP option
Description
The %DUMP command returns a list of information that is specified by the parameter option.
Field option Definition
One of the following:  ALLReturn info about PATROL Agent data structures  APP_INSTSReturn info about each application instance  APPSReturn a list of applications  CHANNELSReturn a list of open PSL global file and process channels  CONSOLESReturn a list of connected consoles  ERRORSReturn a list of PSL errors that have occurred  GLOBALSReturn a list of global channels  KM_LISTReturn a list of loaded KMs  LIBRARIESReturn a list of loaded libraries  PARAMSReturn a list of PATROL Agent parameters  RTLISTReturn info about processes in the Agent run-time queue  RUNQReturn a list of items scheduled in the run queue  TASKSReturn a list of current tasks
5-2
Format
%DUMP CHANNELS
Description
The %DUMP CHANNELS command returns a list of global file and process channels opened using either the fopen() or popen() functions. The output from the %DUMP CHANNELS command contains the same information as that provided by the get_chan_info() function within a PSL program. The PSL interpreter returns the list of global channel information to the console window from which the %DUMP CHANNELS command was executed.
Note
The %DUMP CHANNELS command is one of a series of dump commands available from the command line. Use the %DUMP command (no argument) to obtain a list of items that can be dumped.
5-3
Each line of output from the %DUMP CHANNELS command is a string with the format:
name status details type SHARED readname readpid writepid writename
Field name
Definition
Alphanumeric name given to the channel when it was created as a global channel, or when it was changed from local channel to a global channel. OPEN or CLOSED One of the following:  fopen() channel  file name that is opened or NONE if no file name is open  popen() channel  process ID of the external operating system process to which the channel is attached or 1 if the process has terminated PIPE or FILE One of the following:  Name of the process waiting to read from the channel  NONE if no process is waiting  UNAVAILABLE if there is a process but the name is not available One of the following:  Process ID of the PSL process waiting to read from the channel  1 if no process is waiting One of the following:  Process ID of the PSL process waiting to write to the channel  1 if no process is waiting One of the following:  Name of the process waiting to write to the channel  NONE if no process is waiting  UNAVAILABLE if there is a process but the name is not available
status details
type readname
readpid
writepid
writename
5-4
Format
%DUMP LIBRARIES
Description
Each line of output from the %DUMP LIBRARIES command is a string with the format: <library_name> - <status>, <date>
Definition
The name of the loaded library Indicates if the library has been modified on disk since it was loaded by the Agent The last modification date the library had when it was loaded by the Agent
Example
When typed into the computer window, the command OS>%DUMP LIBRARIES outputs the following:
================ Currently Loaded Libraries ========================= response_def_lib.lib - unmodified, Wed Nov 6 15:34:42 1996 unix_misc_lib.lib - unmodified, Wed Dec 11 13:11:16 1996 set_share_lib.lib - unmodified, Tue Nov 26 16:56:38 1996 =====================================================================
5-5
Format
%PSL statement
Parameter
Parameter statement Definition
One ore more PSL statements or built-in functions that are to be executed. The %PSL command and statement must fit on a single input line.
Description
The %PSL command submits statement to the PSL interpreter for immediate interpretation.
5-6
Format
%PSLPS
Description
The %PSLPS command returns a list of currently scheduled or active PSL processes on the computer system to the console window. The information displayed by the %PSLPS command includes the process identifier (PID) and the name of the PSL process or command.
5-7
Format
psl inputfile -o outfile -n -r -w -l -P -O -q -b -R -e functionname -s librarynames -S
Parameters
Parameter inputfile
-o outfile
Definition
Name of the PSL source file Write the compiled binary output as the file outfile. This option implicitly includes the -n option; that is, the -o option does not schedule outfile for execution after compilation. The PSL compiler may add a .lib or .bin extension to outfile if you selected the -l or -b option respectively. Do not schedule outfile for execution after compilation. Suppress runtime error messages. This option is equivalent to including the statement PslDebug = 0; in the PSL script. Suppress compilation warning messages produced by the PSL compiler. Write the compiled output in library mode as the file
-n -r
-w -l
-P
5-8
Parameter
-O
Definition
Specify the optimizer level. (For more information about optimizer levels, see Optimization Levels on page C-11.) Print the PSL bytecode to the screen Inform the PSL compiler that statically or dynamically loaded libraries are required for the compilation Default if not specified: No statically or dynamically loaded libraries required for the compilation Specify the user-defined function functionname within the PSL source file as the execution entry point for the compiled program Default if not specified: Execution begins with the first statement within inputfile that is not part of a user-defined function definition. Instruct the PSL compiler to statically load all user libraries required for compilation. Default if not specified: Load library names with the .lib extension statically and all other library names dynamically List of user library names that should be statically loaded for compilation. Library names should have the format library_name.lib. The PSL compiler loads any library name without the .lib extension dynamically unless the -l flag is specified. Default if not specified: No user libraries are included. Display the PSL symbol table
-q -R
-e functionname
-s
librarynames
-S
Description
The psl command creates an executable binary file from inputfile and specified librarynames. The stand-alone interpreter will immediately execute the compiled binary if options -o outfile, -l, and -b are omitted. Use this command to create PSL libraries and PSL binaries that can be used in the PATROL Agent. Doing so allows for a significant performance gain.
5-9
The following PSL features cannot be fully simulated with the PSL interpreter: complex built-in functions such as create() and destroy() that rely on the full object hierarchy of the agent multiple PSL process issues such as timeouts or waiting for a lock security issues with functions such as fopen() and cat(), which rely on the user name operating the agents command
5-10
6
6 6
PslDebug Run-Time Error Checking Variable . . . . . . . . . . . . . . . 6-2 errno Error Return Code Variable . . . . . . . . . . . . . . . . . . . . . . . . . 6-6 exit_status System Return Code Variable . . . . . . . . . . . . . . . . . . . 6-7 Incompatibilities with the C Programming Language . . . . . . . . . . . . 6-8 Operators && and || . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-8 Prefix and Postfix Operators ++ and -- . . . . . . . . . . . . . . . . . . . . 6-8 Break and Continue Statements . . . . . . . . . . . . . . . . . . . . . . . . . . 6-9 Common PSL Coding Errors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-10 Character Strings Interpreted as Numbers . . . . . . . . . . . . . . . . . . 6-10 Floating Point Numbers Interpreted as Character Strings . . . . . . 6-11 Character Strings Interpreted as Variable Names . . . . . . . . . . . . 6-11 PSL Functions That Do Not Modify Their Arguments . . . . . . . . 6-12 Functions That Do Not Write to the System Console Window . . 6-13 PSL Compiler Warnings. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-14 Built-in Function Run-Time Error Messages . . . . . . . . . . . . . . . . . . . 6-17
6-1
The format of PslDebug within a PSL script is identical to that of any other PSL variable:
PslDebug = n;
where n is the sum of one or more of the values from Table 6-1.
Table 6-1 PslDebug Error Checking Flag Bits (Part 1 of 3)
Value
Definition
6-2
Table 6-1
Value
Definition
64
128
Function Tracing:
6-3
Table 6-1
Value 512
Definition
Enable function call tracing. Function call tracing reports which functions are called but does not return information about the arguments. Function call tracing traces both user-defined and built-in functions. Enable function argument tracing. Function argument tracing reports the arguments passed to all user-defined or built-in functions. Function argument tracing requires that function call tracing (PslDebug = 512) also be enabled; that is, PslDebug = 1536 for function argument tracing. Enable function return value tracing. Function return value tracing reports the value returned by calls to all user-defined or built-in functions.
1024
2048
Variable Tracing:
4096
Enable variable assignment tracing. Assignment tracing reports the variable name (if available) and the value assigned to it. Enable errno tracing. errno tracing reports any nonzero values stored in the PSL errno variable.
8192
Lock Tracing:
16384
Enable PSL lock tracing Lock tracing reports the interprocess actions that occur during lock() and unlock() function processing, including the granting, denying, and releasing of locks. (not used)
32768
6-4
You set multiple flag bits by equating PslDebug to the sum of their values. For example, PslDebug = 44 would enable the following flags: arithmetic operations involving nonnumeric operands (4) illegal or undefined arithmetic operations (8) PSL Version 2.0 built-in functions (32)
6-5
The user can also write values to the errno variable. However, there should be little cause to set errno since it is reset by all function that set it.
Tip
The errno variable is reset to zero by many built-in functions at the start of their processing; and in some functions, clearing can occur before arguments are processed, leading to errno being cleared before being processed as an argument. Hence, when passing errno as an argument to a built-in function, BMC Software recommends that you make a copy in a temporary variable and pass the copy.
6-6
The popen() function with an OS command type can set the exit_status variable asynchronously whenever its operating system child process dies. It is possible (although unlikely) that the popen() function could set exit_status after a system() or execute() function concludes but before exit_status is read for the system() or execute() call.
6-7
Prefix and Postfix Operators ++ and -Difference: PSL does not distinguish between prefix and postfix operators. C Action: Appending ++ or as a prefix instructs the program increment or decrement the variable then test the condition, while appending ++ or as a postfix instructs the program to test the condition before incrementing or decrementing the variable. PSL Action: PSL treats both prefix and postfix operators as prefix operators. Treating postfix operators as if they were prefix operators may cause unexpected results in statements that depend on postfix operators.
6-8
6-9
The run-time warnings perform the same check as the as arithmetic operators.
Note
These features remain for compatibility with previous releases of PATROL. Arithmetic operators identify the character string 10th May as the number 10 while relational operators correctly identify it as a character string. Its use as an arithmetic operand will not generate a run-time warning. Solution: Be aware that character strings whose first character is a valid numeric representation can cause unexpected results in numeric operations that will not be detected by PSL diagnostics. Avoid the use of such strings.
BMC Software, Inc., Confidential and Proprietary Information
6-10
6-11
The return values for these functions generally indicate the completion status of the operation and may not need to be retained. Solution: Become familiar with the descriptions of the PSL built-in functions. Those that return more than a completion status value probably do not modify their arguments and thus require that you explicitly save the return value if it is to be available to other statements within the program.
6-12
6-13
Problem: The assignment operator = appeared in an if statement condition. Reason: The usual assignment operator within an if statement condition is the test equal operator ==. Using = instead of == may be a useful coding technique or may indicate an error. Solution: Verify that the if statement condition operator is the desired one.
Problem: The PSL statement is a NULL effect statement without assignment, increment, or side-effect function calls. Reason: The statement may produce an effect during execution but does not transmit that effect to any other part of the PSL program, which is the reason the statement is considered a NULL effect statement. An example with operators is x+2; which should probably be x+=2;. Another example of errors with function calls is trim(); which should probably be var=trim(); because the returned value is unused. Solution: Examine the statement and modify it to give it an effect within the program.
6-14
Problem: A local PSL variable has been used without ever having been initialized to a value. Reason: Flags within the PslDebug variable allow PSL to flag all local variables whose first appearance in a program is not as the recipient of an assignment statement. When a variable is created, its value defaults to the NULL string. This message is warning you that the variable in question has not been previously defined within the PSL program. Solution: Ensure that the variable and its NULL string value are desired within the statement.
line_number Variable set but not used
Problem: A variable was defined but not otherwise used in the PSL program. Reason: A variable was created when it was assigned a value other than the default NULL string value, but the variable was never used within the PSL program. A message that a variable was used but not set often indicates that a typographical error occurred and that PSL created two variables, one with the correct name and the other with the misspelled one. Solution: Check to see why the variable was never used within the program. If it is not needed, remove it. If it is a typographical error, correct it.
line_number Undefined backslash escape in string constant
Problem: An undefined escape sequence appeared in a PSL character string. Reason: The correct PSL escape sequences are \A through \Z , \t, \n, \r, and \b. PSL ignores and discards any other escape sequences that it detects in a character string. For example, PSL changes the string A\zB to the string AB because \z is not a valid escape character. Solution: Verify the presence of the escape character in the character string and either modify it to be a valid PSL escape character or remove it.
BMC Software, Inc., Confidential and Proprietary Information
6-15
Problem: A floating point number begins with a decimal point. Reason: Floating point numbers within PSL must begin with either a minus sign or a digit in order for PSL to correctly interpret them as numbers in numeric calculations. PSL will interpret a number that begins with a decimal point as a character string and will treat it as a character string in numeric operations. Solution: Prefix each floating point number with 0 or a minus sign to ensure it is properly interpreted by PSL.
6-16
Reason: The cat() function had problems opening the file such as file not found or permission denied. The system error message is reported using the PSL errno variable.
BMCcat: filename -- read error after number bytes
Reason: The cat() function read operation failed after number bytes were read.
BMCcreate: unknown application application.
Reason: The create() function could not locate application in the computer symbol table.
BMCcreate: __type__ missing in object object.
Reason: The create() function could not find the special built-in variable __type__ in the symbol table.
BMCcreate: object object is not an application.
Reason: The create() function determined that the object being created is not an application. The create() function cannot create computer instances.
6-17
Reason: The create() function could not find the special built-in variable __self__ in the symbol table.
BMCcreate: cannot create instance instance of application application.
Reason: The create() function discovered that either the name application is bad or that too many instances are already registered for application.
BMCcreate: invalid initial state state for instance instance of application application.
Reason: The create() function discovered that the state passed to it is not one of the valid states: ALARM, OK, WARN, or OFFLINE.
BMCcreate: empty symbol table in object object.
Reason: The create() function discovered that the symbol table for object is empty, as would be the case if object were the parent of a computer instance. The create() function cannot create computer instances.
BMCchange_state: unknown object object.
Reason: The change_state() function could not find object whose state was to change.
BMCchange_state: __type__ missing in object object.
Reason: The change_state() function could not find the special built-in variable __type__ in the symbol table.
BMCchange_state: object object is not an application instance
Reason: The change_state() function attempted to change state of a computer instance or other non-application instance object.
6-18
Reason: The change_state() function could not find the special built-in variable __self__ in the symbol table.
BMCchange_state: empty symbol table in object object.
Reason: The change_state() function discovered that the symbol table for object is empty, as would be the case if object were the parent of a computer instance.
BMCdestroy: unknown object object.
Reason: The destroy() function could not find object that it was to destroy.
BMCdestroy: __type__ missing in object object.
Reason: The destroy() function could not find the special built-in variable __type__ in the symbol table.
BMCdestroy: object object is not an application instance
Reason: The destroy() function attempted to destroy a computer instance or other non-instance object. The name object must be an application name.
BMCdestroy: __self__ missing in object object.
Reason: The destroy() function could not find the special built-in variable __self__ in the symbol table.
BMCdestroy: empty symbol table in object object.
Reason: The destroy() function discovered that the symbol table for object is empty, as would be the case if object were the parent of a computer instance.
6-19
Reason: The execute() command failed to find instance in the symbol table and so could not execute a command against it.
BMCexecute: cannot get type of object object
Reason: The execute() command could not find the special built-in variable __type__ in the symbol table.
BMCexecute: object object is not an application instance or computer
Reason: The execute() command discovered that object is neither an application nor a computer instance and could not execute a command against it.
BMCexecute: cannot get instance ptr of object object
Reason: The execute() command could not find the special built-in variable __self__ in the symbol table.
BMCexecute: couldnt execute command_type command
Reason: The execute() command was unable to create either the internal run-time cell or the operating system process to execute the command. Possible causes include the following: invalid user ID bad application instance PSL program did not compile or PSL process creation failed
Reason: The execute() function encountered an internal PSL problem. Contact your BMC Software Product Support representative for assistance.
6-20
Reason: The grep() function discovered that the regular expression argument passed to it is either not valid or too long.
BMCget_vars: unknown object object
Reason: The get_vars() function either could not find object; or discovered that object does not have variables (simple variables do not have variables)
Reason: The in_transition() function could not find object on which it was to act.
BMCin_transition: __type__ missing in object object.
Reason: The in_transition() function could not find the special built-in variable __type__ in the symbol table.
BMCin_transition: object object is not an application instance
Reason: The in_transition() function attempted to apply its timer to a computer instance or other nonapplication instance object.
BMCin_transition: __self__ missing in object object.
Reason: The in_transition() function could not find the special built-in variable __self__ in the symbol table.
6-21
Reason: The in_transition() function discovered that the symbol table for object is empty as would be the case if it were the parent of a computer instance.
BMCread: bad channel# channel_number
Reason: The read() function has discovered that channel_number is no longer valid for the PSL process. Possible causes include a bad channel number (for example, a negative number) a channel already closed using the close function
Reason: The readln() function has discovered that channel_number is no longer valid for the PSL process. Possible causes include a bad channel number (for example, a negative number) a channel already closed using the close function
Reason: The write() function has discovered that channel_number is no longer valid for the PSL process. Possible causes include a bad channel number (for example, a negative number) a channel already closed using the close function.
Reason: The set() function attempted to set variable in the PATROL hierarchy that has write permission but is not of a type that the set() function is allowed to modify. For example, this error occurs if variable is another subobject such as an application or instance.
6-22
Reason: The set() function attempted to set a read-only built-in variable in the PATROL hierarchy.
6-23
6-24
A
A A
This appendix lists the codes returned by the PSL errno variable.
A-1
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43
E_PSL_NO_ERROR E_PSL_CAT_MEMORY_FAILURE E_PSL_CAT_READ_ERROR E_PSL_CHANGE_STATE_EMPTY_SYMBOL_TABLE E_PSL_CHANGE_STATE_INTERNAL_FAILURE E_PSL_CHANGE_STATE_INVALID_STATE E_PSL_CHANGE_STATE_NOT_APPLICATION E_PSL_CHANGE_STATE_UNKNOWN_OBJECT E_PSL_CLOSE_BAD_CHANNEL E_PSL_CREATE_ALREADY_EXISTS E_PSL_CREATE_BAD_STATE E_PSL_CREATE_CANNOT_CREATE E_PSL_CREATE_EMPTY E_PSL_CREATE_EMPTY_SYMBOL_TABLE E_PSL_CREATE_INTERNAL_FAILURE E_PSL_CREATE_INACTIVE_APPLICATION E_PSL_CREATE_NOT_APPLICATION E_PSL_CREATE_UNKNOWN_APPLICATION E_PSL_CREATE_SUPPRESSED E_PSL_DESTROY_EMPTY_SYMBOL_TABLE E_PSL_DESTROY_INTERNAL_FAILURE E_PSL_DESTROY_NOT_APPLICATION E_PSL_DESTROY_UNKNOWN_OBJECT E_PSL_EXECUTE_BAD_INSTANCE E_PSL_EXECUTE_CANNOT_CREATE_CHANNEL E_PSL_EXECUTE_CANNOT_EXECUTE E_PSL_EXECUTE_INTERNAL_FAILURE E_PSL_EXECUTE_NOT_IMPLEMENTED E_PSL_EXECUTE_NOT_INSTANCE E_PSL_FILE_CANNOT_OPEN E_PSL_FILE_NOT_FOUND E_PSL_FILE_READ_ERROR E_PSL_FILE_SECURITY_FAILED E_PSL_FILE_STAT_FAILED E_PSL_FOPEN_BAD_MODE E_PSL_FOPEN_CANNOT_CREATE_CHANNEL E_PSL_FOPEN_CANNOT_OPEN_FILE E_PSL_FOPEN_FILE_NOT_FOUND E_PSL_FOPEN_STAT_FAILED E_PSL_GETENV_NOT_FOUND E_PSL_GET_CHAN_INFO_BAD_CHANNEL E_PSL_GET_NOT_FOUND E_PSL_GET_OBJECT E_PSL_GET_VARS
BMC Software, Inc., Confidential and Proprietary Information
A-2
44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87
E_PSL_GREP_BAD_REGEXP E_PSL_IN_TRANSITION_EMPTY_SYMBOL_TABLE E_PSL_IN_TRANSITION_INTERNAL_FAILURE E_PSL_IN_TRANSITION_NOT_APPLICATION E_PSL_IN_TRANSITION_UNKNOWN_OBJECT E_PSL_PRINTF_FORMAT E_PSL_PRINTF_STAR E_PSL_PRINTF_TOO_FEW E_PSL_PROC_EXISTS_BAD E_PSL_READLN_BAD_CHANNEL E_PSL_READ_BAD_CHANNEL E_PSL_READ_FAILED E_PSL_READ_FAILED_MEMORY E_PSL_READLN_TRUNCATED E_PSL_SET_NON_MODIFIABLE E_PSL_SET_SYMBOL_TABLE E_PSL_SET_WRITE_PERMISSION E_PSL_WRITE_BAD_CHANNEL E_PSL_WRITE_CHANNEL_CLOSED E_PSL_WRITE_FAILED E_PSL_WRITE_READ_ONLY E_PSL_BAD_UNLOCK E_PSL_BAD_UNLOCK_NOT_OURS E_PSL_BAD_LOCK_WAITING E_PSL_EDOM E_PSL_ERANGE E_PSL_FOPEN_BAD_CHMOD E_PSL_FOPEN_BAD_CHOWN E_PSL_FOPEN_BAD_ACCOUNT E_PSL_PRINTF_LARGE_ARGUMENT E_PSL_SORT_BAD_MODE E_PSL_HISTORY_BAD_OBJ E_PSL_HISTORY_NOT_PARAM E_PSL_HISTORY_NO_RTCELL E_PSL_HISTORY_NO_INFO E_PSL_HISTORY_BAD_FORMAT E_PSL_FSEEK_PIPE_CHANNEL E_PSL_FSEEK_BAD_CHANNEL E_PSL_FTELL_PIPE_CHANNEL E_PSL_FTELL_BAD_CHANNEL E_PSL_RESPONSE_NO_VALUE E_PSL_RESPONSE_NO_CONSOLE E_PSL_RESPONSE_TIMEOUT E_PSL_SHARE_BAD_CHANNEL
A-3
88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128
E_PSL_SHARE_SAME_CHANNEL E_PSL_CLOSE_BUSY_CHANNEL E_PSL_BUSY_CHANNEL E_PSL_UNBLOCKED_BY_CLOSE E_PSL_FULL_DISCOVERY_BAD_APP E_PSL_NO_SUCH_ID E_PSL_SOCKET_BUSY E_PSL_TIMEOUT E_PSL_BAD_FUNCTION_PARAMETER E_PSL_SNMP_NOT_SUPPORTED E_PSL_SNMP_ALREADY_LISTENING E_PSL_SNMP_NOT_LISTENING E_PSL_SNMP_ERROR E_PSL_BAD_OBJ E_PSL_NOT_PARAM E_PSL_NO_RTCELL E_PSL_NOT_SUPPORTED E_PSL_ANN_NO_HISTORY_RETENTION E_PSL_REMOTE_QUERY_COMM_ERR E_PSL_REMOTE_QUERY_CREATION E_PSL_REMOTE_QUERY_CANNOT_START E_PSL_REMOTE_OPEN_ERR E_PSL_FAULT E_PSL_BAD_DATE_STRING E_PSL_BAD_TIMEZONE E_PSL_CANNOT_DETERMINE_TIMEZONE E_PSL_LOCK_DESTROYED E_PSL_ANN_TOO_EARLY E_PSL_ANN_SAVE_FAILED E_PSL_ACL_FAILED E_PSL_PCONFIG_FAILED E_PSL_NO_ANNOTATION_DATA E_PSL_BAD_CHART_COMMAND E_PSL_ALLOC_FAILED E_PSL_INTERNAL_ARG_ERROR E_PSL_INTERNAL_PARSE_FAILED E_PSL_INTERNAL_UNKNOWN_FUNCTION E_PSL_INTERNAL_FUNCTION_FAILED E_PSL_INTERNAL_TYPE_MISMATCH E_PSL_INTERNAL_BAD_NAME E_PSL_ALREADY_WAITING
A-4
B
B B
B-1
Mode
rrrrrrrrrrrrrrrrrrrrrrrrrobjectId appType sid name hostname ipAddress tcpPort
Name
Object ID
Description
Application name (computer class) Host name Host name Host name Hosts IP address TCP port to which PATROL Agent is bound PATROL home directory Version of the PATROL Agent software Status of the instance based on discovery information only Name of worst parameter on this computer Status of worst parameter on this computer Overall status of this instance (worst of ruleState, worstParamState and worstApplInstState) TRUE if global parameters have been suspended for this computer, FALSE otherwise TRUE if parameters for this computer are allowed to be executed, FALSE otherwise PID of the PATROL Agent process Full path name of the PATROL Agent's error log file PID of the PATROL Agents server process Full path name of the server's error log file Total number of errors detected by the PATROL Agent Number of memory allocation errors Number of process spawning errors Number of pipe creation errors Number of miscellaneous internal errors Number of errors in user-specified commands
patrolHome patrolVersion ruleState worstParam worstParamState status globalParamsSuspended execParams agentPid agentLogPath serverPid serverLogPath totalErrors allocErrors forkErrors pipeErrors internalErrors userErrors
B-2
Table B-1
Mode
rrrr-
Name
executingProcs execsPerMin timeBtnExecs time
Description
Number of currently executing sub-processes (parameters, commands, and so on) Average number of sub-processes started per minute Average time (in seconds) between spawning of sub-processes Current time as ASCII string (e.g. Thu May 07 02:44:01 1992)
B-3
Mode
rrrrw rrrrrrr. .. name active
Name
Description
Symbol table for application Symbol table for computer Application name TRUE if discovery for application is active, FALSE otherwise Time (in seconds from Epoch) at which discovery of this application was last done Application user name Application password TRUE if the state of this application is automatically propagated to the computer Environment variables List of SIDs of instances of this application Number of instances of this application
Mode
rrrrrrw rrrw . .. objectId appType sid name username password
Name
Description
Symbol table for instance Symbol table for application Object ID Application name SID for instance Icon name/label for instance Application user name Application password Environment variables
BMC Software, Inc., Confidential and Proprietary Information
environment
B-4
Table B-3
Mode
rw rw rrrrrrrrrrrrrrrrrrhome version ruleState
Name
Description
Home directory for instance Instance version (software) Status of the instance based on discovery information only Name of worst parameter on this instance Status of worst parameter on this instance Overall status of this instance (worst ofruleState and worstParamState) TRUE if global parameters have been suspended for this instance, FALSE otherwise TRUE if parameters for this instance are allowed to be executed, FALSE otherwise Time (in seconds from Epoch) at which instance entered state transition, or zero if not in transition User names of processes belonging to this instance PIDs of processes belonging to this instance Parent PIDs of processes belonging to this instance Names of processes belonging to this instance Full commands of processes belonging to this instance Sizes (virtual) of processes belonging to this instance Sizes (resident) of processes belonging to this instance States of processes belonging to this instance CPU utilization for processes belonging to this instance Cumulative CPU consumption for processes belonging to this instance Path to the nested instances parent instance
worstParam worstParamState status globalParamsSuspended execParams transition procUser procPid procParentPid procName procCommand procSize procResidentSetSize procStatus procPercentCpu procCpuTime parentInstance
B-5
Mode
rrrrw rw rrw rw rrr. .. name active status execTime interval value alarmMin alarmMax
Name
Description
Symbol table for parameter Symbol table for instance/computer Parameter name Parameter activity State of the parameter Time of next scheduled execution Interval (in seconds) between executions Current value Minimum value of current alarms range, or zero if no alarm is active Maximum value of current alarms range, or zero if no alarm is active State of current alarm, or No alarm active if no alarm is active.
alarmState
B-6
C
C C
This appendix describes additional PSL tools you can use when writing PSL scripts. The additional PSL tools are The PSL Profiler Tool . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .C-2 Introduction to the PSL Profiler. . . . . . . . . . . . . . . . . . . . . . . . . .C-2 How to Install the PSL Profiler . . . . . . . . . . . . . . . . . . . . . . . . . .C-4 How to Start the PSL Profiler . . . . . . . . . . . . . . . . . . . . . . . . . . .C-5 PSL Profiler PSL Functions. . . . . . . . . . . . . . . . . . . . . . . . . . . . .C-5 About the PSL Profile Viewer (ppv) Tool . . . . . . . . . . . . . . . . . .C-8 About the PSL Profiler API . . . . . . . . . . . . . . . . . . . . . . . . . . . . .C-9 The PSL Optimizer Tool . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .C-10 Introduction to the PSL Optimizer. . . . . . . . . . . . . . . . . . . . . . . .C-10 How to Install the PSL Optimizer . . . . . . . . . . . . . . . . . . . . . . . .C-10 How to Deactivate the PSL Optimizer. . . . . . . . . . . . . . . . . . . . .C-11 About the PSL Optimizer. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .C-11 Optimization Levels. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .C-11 Optimization Criteria . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .C-15 Command-Line Specified Options . . . . . . . . . . . . . . . . . . . . . . .C-17
C-1
C-2
There are a number of interfaces to the PSL Profiler: PSL functions The PSL Profiler can be dynamically enabled via PSL and reports can printed in PSL. PSL Profiler Viewer (ppv) utilityThe tool is an off-line reporting tool that analyzes a profiling data file which the PATROL Agent can generate during profiling. PSL Profiler APIThe PSL Profiler API allows the PSL Profiler to be controlled (started, stopped, etc.) and queried at run-time.
PATROL Versions
The list of PSL processes currently running in the Agent can be sampled and used to generate a rough picture of the cost of each PSL process. Use this tool as a sampling technique for PATROL v3.1 products in lieu of the PSL Profiler offered in v3.2.
Resource Requirements
No additional resource requirements beyond those specified for running the PATROL for Windows NT product.
C-3
The primary purpose of the PATROL profiling tools in the KM development environment is to aid in the KM performance tuning task. Use the PSL Profiler to tune the CPU usage of a PSL script find the highest consuming PSL script tune the number of external processes
The Profiler tools can also be used as an PATROL Agent configuration or deployment tool in production systems to determine which KMs and PSL scripts are taking too much resources.
Limitations of the PSL Profiler
The main limitation of the PSL Profiler is that it does not go very deep within each script to examine performance. For example, there is no line-by-line report showing which lines are executed most. The analysis of built-in functions is useful but there is no similar analysis of PSL user-defined functions. The PSL Profiler can be dynamically enabled and disabled during Agent execution. Enabling the PSL Profiler will turn on the measurement for the specified PSL scripts. Disabling the Profiler will discard all measured data and return the Agent to the normal non-profiling state. The impact of turning on the PSL Profiler is a marginal degradation of PSL execution performance. This results because each PSL timeslice must also be added to measurement counters. However, this is mainly an low in-memory cost. The largest costs are when the reports are generated. Report generation occurs only when the data has been collected.
C-4
In all cases, the output report is of a similar format. The PSL Profiler reports tell you which PSL scripts have the highest CPU usage and also measure how much each built-in PSL function has used. Scheduling frequency of the PSL processes affects the results since the CPU usage timers are cumulative. However, since the number of executions is also measured, the average cost per execution can also be easily generated in reports. Profiler output is saved in the file specified by the PSL_PROF_LOG environment variable.
Description
Sets the default Profiler options to options Retrieves the profile of the process identified by pid Retrieves the total real, user, and CPU time as well as the percent of CPU usage Sets the profiling options of the process identified by pid to options Resets the profiling data for all processes Retrieves the profiles of the top_procs highest CPU time processes
C-5
ProfDefaultOptions()
The default Profiler options are queried or changed by using the ProfDefaultOptions() function, with the following format:
ProfDefaultOptions(options)
This function sets the default profiler options to options. If options is omitted, then the current default options are returned. Changing the default Profiler options does not affect the profiling options of existing processes.
ProfGet()
The profiles of one or more PSL processes are retrieved by using the ProfGet() function, with the following format:
ProfGet(pid,top_funcs)
This function retrieves the profile of the process identified by pid. If pid is 1 or , then the profiles of all existing PSL processes are returned. If top_funcs, which is a numeric value, is specified, then only top_funcs highest CPU-time function calls are returned to the profile of each process. Otherwise, all function call data available for each process is returned.
ProfGetTotalCpu()
The total CPU usage statistics for the current interval (since profiling was started or reset) are retrieved by the ProfGetTotalCpu() function, with the following format:
ProfGetTotalCpu()
The ProfGetTotalCpu() function returns, in order, the real CPU time, user CPU time, system CPU time, and CPU percent in the following format:
C-6
2:25:52.275 ProfOptions()
0:01:07.998
0:00:14.200
0.94
The profiling options of existing processes are queried or changed by using the ProfOptions() function, with the following format:
ProfOptions(pid,options)
This function sets the profiling options of the process identified by pid to options. If pid is -1 or , then the profiling options of all existing processes are changed to options. If options is omitted, then the current profiling options of the process identified by pid are returned.
ProfReset()
The profiling data for all processes are reset by using the ProfReset() function, with the following format:
ProfReset()
This function resets the profiling data of all processes and sets the profiliers reference point to the current time so the future ProfGetTotalCpu() function call reflects the totals from the ProfReset() function call.
ProfTop()
The profiles of the highest CPU time-consuming processes are retrieved by using the ProfTop() function, with the following format:
ProfTop(pid,top_procs,top_funcs)
This function retrieves the profiles of the top_procs highest CPU-time processes. If top_funcs is specified, then only top_funcs highest CPU-time functions calls are returned in the profile of each process. Otherwise, all function call data available for each process is returned. Note that top_procs and top_funcs are both numeric values.
C-7
The PSL process data includes number of executions and real and CPU times used by each process as well as number of calls, and a breakdown of the real and CPU time used by each function that a process calls. All of this information is sorted in descending order by the highest CPU time and by the name in the event that two processes (or function calls) have the same cumulative CPU time.
C-8
When a process is first created, it is assigned the current default Profiler options. The default Profiler options are 15 if the Agent is started with the -profiling option (-p option for the PSL stand-alone) or 0 otherwise.
C-9
PATROL Versions
Resource Requirements
No additional resource requirements beyond those specified for running the PATROL product.
When to Use the PSL Optimizer
C-10
Optimization Levels
You can specify the level of optimization by using the -O flag with the PSL stand-alone compiler or with the PatrolAgent function. You can also use the pragma keyword in PSL to set the optimization level for a particular PSL script. The supported levels of optimization are:
Level Code 0 1 2 3 Description
No optimization Peephole optimization (default) Local optimization Global optimization
C-11
Level 1 optimizations are ignorant of a programs control flow and are limited to the analysis of a program on an instruction by instruction basis. Level 1 optimizations include Jump chain reduction Useless jump removal Redundant instruction removal Parameter packing
This optimization looks for unconditional jumps to one or more Control Transfer Statement (CTS) instructions. The terminal CTS instruction is then replicated onto all of the non-terminal CTS instructions.
Useless Jump Removal
This optimization looks for unconditional and conditional jumps to the next instruction. The jump is then removed.
Redundant Instruction Removal
This optimization looks for redundant statements without side effects. One of the redundant statements is then removed.
Parameter Packing
This optimization looks for adjacent parameter instructions and packs them into a more efficient parameter instruction.
C-12
Level 2 optimizations utilize a flowgraph to optimize the program one basic block at a time. Code motion, addition, and removal are limited to a basic block unit. Level 2 optimizations include Constance folding Constance propagation Global constance propagation Definition removal String concatenation conversion Parameter ordering
Constant Folding
Expressions whose arguments are known at optimization time are evaluated. The result of the folded expression replaces the original expression with an assignment operation.
Constant Propagation
The results of constant folding are tracked and propagated into other expressions using the value. These values can then be folded into other expressions.
Global Constant Propagation
The values of symbols used in subsequent basic blocks are seeded for future Level 2 fold and propagate optimizations.
Definition Removal
Expressions defining symbols that are later defined, without first being referenced, are removed. Expressions with side effects remove only the assignment to the symbol.
C-13
Chains of string concatenations are converted into a single and more efficient call to the PSL join() function.
Parameter Ordering
Parameter statements with nested expressions are re-ordered so all expression evaluation occurs before the first parameter statement and all parameter statements immediately precede the call statement. This exposes Level 1 parameter packing opportunities.
Level 3: Global Optimizations
Level 3 optimizations alter the flowgraph by adding, removing, and re-locating basic blocks. Level 3 optimizations include Block chain reduction Unreachable code removal Loop tail logic injection Orphan block inlining
One or more basic blocks that are entered from an unconditional jump are copied to the jump point. The resultant basic block is then extended to include the copied block.
Unreachable Code Removal
Loops with conditional heads and unconditional tails are converted so that the condition evaluation takes place in the loops tail(s). This decreases loop overhead by removing an unnecessary jump to the condition block.
BMC Software, Inc., Confidential and Proprietary Information
C-14
Blocks that are entered exclusively via jumps are inlined (moved) into the innermost loop that references this block.
Optimization Criteria
The PSL Optimizer decides at what level to optimize a program based on the following criteria:    the requested level the demanded level the maximum level
The requested level is implicitly defined based on the context of the call to the PSL Compiler. For example, a PSL parameter script will request Level 3 global optimization when it is compiled. A script submitted via the %PSL command will request the default level (Level 1 peephole) of optimization when it is compiled. Presently, Level 3 global optimization is requested for all pre-discovery, discovery, and parameter PSL scripts. The default Level 1 is used for all other commands.
Demanded Level of Optimization
The demanded level is explicitly defined and takes precedence over the requested level. The demanded level can be specified on the command line or directly in the PSL program via the pragma statement. For example, a parameter can demand Level 2 optimization (and thus override the Level 3 request) by inserting the following pragma statement in the program
pragma O2;
C-15
Note
Note that the O in the O2 in the line above is an alpha capital letter and not a number zero. Likewise, the optimization level can be specified system-wide via the command line:
PatrolAgent -02 Note
Note that the 0 in the 02 in the line above is a numeric and not an alpha capital letter O. This will cause all PSL scripts to be optimized at Level 2 except for any scripts containing a pragma statement requesting another level of optimization.
Maximum Level of Optimization
The maximum level is explicitly defined and takes precedence over the demanded level and the requested level. The maximum level restricts the Optimizer tool from invoking higher levels. For example, if a parameter specifies a maximum optimization level of 1, it will never get optimized at Levels 2 or 3. A program specifying a maximum level can use a pragma statement like this:
pragma -OM1;
Example # This program will be optimized at level 1 and # print the levels 1 and 2 results for the # program and its processes. pragma -01P2
C-16
Likewise, the maximum level can be specified system-wide via the command line. For example,
PatrolAgent -OM1
Specifying a maximum level of zero (0) turns off the PSL Optimizer tool.
M# P#
C-17
C-18
Index
Index
Symbols
# character 3-2 %DUMP 5-2 %DUMP CHANNELS 5-3 %DUMP LIBRARIES 5-5 %PSL - execute PSL statement 5-6 %PSLPS - list PSL processes 5-7 {} 3-2 application objects 1-11 application variables 1-11 arithmetic operators 2-10 asctime() date/time 4-16 asin() arcsine 4-19 assignment operators 2-11 atan() arctangent 4-20 atexit() call at end of process 4-22
A
acos() arccosine 4-8 ActiveX scripts 2-8, 4-116 annotate() annotate parameter value 4-9 annotate_get() return parameter annotation 4-14 application class built-in macro variables B-4 application discovery 1-9 application discovery functions full_discovery() verify mode 4-134 in_transition() allow state change 4-160 proc_exists() verify process 4-213 process() process status 4-214 application instance B-4 application instances 1-11
BMC Software, Inc., Confidential and Proprietary Information
B
backslash rules 2-6 bitwise operators 2-12 blackout() hide state changes 4-24 block chain reduction optimization C-14 built-in Agent namespace variables 1-13, B-4 for application class B-4 for application instance B-4 for computer B-2 for parameter B-6 built-in functions 4-104 acos() arccosine 4-8 annotate() annotate parameter value 4-9 annotate_get() return parameter annotation 4-14 asctime() date/time 4-16
Index
asin() arcsine 4-19 atan() arctangent 4-20 atexit() call at end of process 4-22 blackout() hide state changes 4-24 cat() return file contents 4-29 ceil() integer ceiling 4-31 chan_exists() verify channel 4-32 change_state() change object state 4-33 chart() load/destroy/print chart 4-35 close() close channel 4-39 cond_signal() signal process 4-41 cond_wait() process wait 4-42 console_type() identify PATROL Developer Console 4-46 convert_base() convert base 4-47 convert_date() return system time 4-49 cos() cosine 4-52 cosh() hyperbolic cosine 4-55 create() create object 4-47, 4-57 date() date/time 4-62 debugger() suspend for debug 4-63 desktop() execute PATROL link command 4-64 destroy() destroy object 4-65 destroy_lock() destroy process lock 4-66 difference() unique to list 4-67 dump_hist() history data 4-69 encrypt() encrypt a string 4-73 event_archive() archive PATROL events 4-75 event_catalog_get() return catalog information 4-81 event_check() count matching events 4-84 event_query() print matching events 4-88 event_range_manage() change status of event range 4-95 event_range_query() return events from an ID range 4-97
event_report() return event report 4-99 event_trigger() create PATROL event 4-111 event_trigger2() create PATROL event 4-113 execute() submit command 4-115 exists() verify object 4-118 exp() e to a power 4-120 fabs() absolute value 4-121 file() file information 4-122 floor() integer floor 4-124 fmod() floating point remainder 4-125 fopen() open file channel 4-126 fseek() set file position 4-130 ftell() file position 4-132 full_discovery() verify mode 4-134 get() get value 4-135 get_chan_info() channel status 4-136 get_ranges() return alarm range settings 4-144 get_vars() list variables 4-148 getenv() object environment 4-140 getpid() return process ID 4-142 getpname() get process name 4-143 grep() match expression 4-150 history() return history 4-152 history_get_retention() return retention value 4-155 in_transition() allow state change 4-160 index() locate string 4-156 int() return integer 4-157 internal() process internal to PATROL Agent 4-158 intersection() set intersection 4-159 is_var() verify variable 4-164 isnumber() verify expression 4-162 join() join strings together 4-165 kill() terminate PSL process 4-166 length() count characters 4-167 lines() count lines 4-168
BMC Software, Inc., Confidential and Proprietary Information
lock() request lock 4-169 log() record event 4-172 log10() logarithm (10) 4-175 loge() logarithm (e) 4-173 ntharg() return text match 4-177 nthargf() return text match 4-180 nthline() return lines 4-183 nthlinef() return lines 4-185 num_consoles() number of registered consoles 4-187 pconfig() configure PATROL Agent 4-189 popen() process channel 4-201 pow() raise to a power 4-206 print() formatted output 4-208 printf() C output format 4-209 proc_exists() verify process 4-213 process() process status 4-214 PslExecute() start PSL process 4-217 PslSetOptions() set run-time options 4-219 random() random numbers 4-220 read() channel read 4-222 readln() read line 4-224 refresh_parameters() execute PATROL parameters 4-226 remote_close() end remote agent session 4-228 remote_event_query() return remote agent events 4-229 remote_event_trigger() create remote agent event 4-235 remote_file_send() copy file to remote agent 4-237 remote_open() open remote agent session 4-242 remove() remove system file 4-250 replace() replace string in text 4-252 response() create dialog 4-253
response_get_value() return dynamic dialog status 4-311 rindex() last occurrence 4-314 set() set variable 4-316 share() make global channel 4-321 sin() sine function 4-323 sinh() hyperbolic sine 4-325 sleep() suspend process 4-327 snmp_agent_config() configure SNMP agent 4-329 snmp_agent_start() start SNMP agent 4-331 snmp_agent_stop() stop SNMP agent 4-332 snmp_close() close SNMP session 4-333 snmp_config configure SNMP session 4-335 snmp_get() return MIB variables 4-341 snmp_get_next() get next MIB variable 4-343 snmp_h_get() get MIB variable fast 4-345 snmp_h_get_next() return next variable fast 4-348 snmp_h_set() set MIB variables fast 4-351 snmp_open() open SNMP session 4-354 snmp_set() set MIB variables 4-356 snmp_trap_ignore() ignore SNMP traps 4-359 snmp_trap_listen() accumulate SNMP traps 4-360 snmp_trap_raise_std_trap() raise PATROL trap 4-363 snmp_trap_receive() receive SNMP traps 4-364 snmp_trap_register_im() PATROL trap receiver list 4-368
Index
snmp_trap_send() send SNMP trap 4-371 snmp_walk() subsequent MIB variables 4-373 sort() sort list 4-375 sprintf() print as string 4-378 sqrt() square root 4-383 srandom() seed random number 4-385 subset() verify subset 4-386 substr() return substring 4-388 system() submit command 4-389 tail() last text lines 4-391 tan() tangent 4-393 tanh() hyperbolic tangent 4-395 time() seconds since 01/01/70 4-397 tmpnam() temporary file name 4-398 tolower() all lower case 4-399 toupper() all upper case 4-400 trace_psl_process() enable tracing 4-401 trim() remove characters 4-403 union() merge lists 4-405 unique() remove duplicate elements 4-407 unlock() release lock 4-408 unset() remove set() object 4-410 va_arg() return next argument 4-411 va_start() reset argument list 4-413 write() write to channel 4-415
C
case, significance of 2-3 cat() return file contents 4-29 ceil() integer ceiling 4-31 chan_exists() verify channel 4-32 change_state() change object state 4-33 channel execution functions popen() process channel 4-201 chart() load, destroy, print a chart 4-35 close() close channel 4-39
4 PATROL Script Language Reference Manual
collector parameter 1-10 combined state 4-34 command functions chan_exists() verify channel 4-32 close() close channel 4-39 desktop() execute PATROL link command 4-64 execute() submit command 4-115 fopen() open file channel 4-126 get_chan_info() channel status 4-136 internal() process internal to PATROL Agent 4-158 share() make a global channel 4-321 system() submit command 4-389 comments in PSL 3-2 common coding errors 6-10 compiler warnings 6-14 compound statements 3-2 computers built-in Agent namespace variables B-2 cond_signal() signal process 4-41 cond_wait() process wait 4-42 condition functions cond_signal signal process 4-41 cond_wait() process wait 4-42 Console functions response_get_value() return dynamic dialog status 4-311 console_type() identify PATROL Developer Console 4-46 constant folding optimization C-13 constant propagation optimization C-13 consumer parameter 1-10 convert_base() convert base 4-47 convert_date() return system time 4-49 cos() cosine 4-52 cosh() hyperbolic cosine 4-55 create() create object 4-47, 4-57
D
data types, PSL 2-2 date() date/time 4-62 debugger() suspend for debug 4-63 debugging functions debugger() suspend for debug 4-63 decrement operators 2-12 definition removal optimization C-13 desktop() execute PATROL link command 4-64 destroy() destroy object 4-65 destroy_lock() destroy process lock 4-66 diagnosing PSL errors 6-1 difference() unique to list 4-67 differences from C 6-8 discovery script 1-9 do...until statement 3-4 dump_hist() history data 4-69
E
efficiency 1-10 encrypt() encrypt a string 4-73 errno return code 6-6 error checking run-time 6-2 errors diagnosing 6-1 event functions event_archive() archive PATROL events 4-75 event_catalog_get() return catalog information 4-81 event_check() count matching events 4-84 event_query() print matching events 4-88
event_range_manage() change status of event range 4-95 event_range_query() return events from an ID range 4-97 event_report() return event report 4-99 event_schedule() schedule PATROL events 4-104 event_trigger() create PATROL event 4-111 event_trigger2() create PATROL event 4-113 event_archive() archive PATROL events 4-75 event_catalog_get() return catalog information 4-81 event_check() count matching events 4-84 event_query() print matching events 4-88 event_range_manage() change status of event range 4-95 event_range_query() return events from an ID range 4-97 event_report() return event report 4-99 event_schedule() schedule PATROL events 4-104 event_trigger() create PATROL event 4-111 event_trigger2() create PATROL event 4-113 execute() submit command 4-115 exists() verify object 4-118 exit statement 3-6 exit_status system return code 6-7 exp() e to a power 4-120 export statement 3-7 expressions, PSL 2-9 External commands %DUMP 5-2 %DUMP CHANNELS 5-3 %DUMP LIBRARIES 5-5 %PSL - execute PSL statement 5-6 %PSLPS - list PSL processes 5-7
Index
F
fabs() absolute value 4-121 file functions cat() return file contents 4-29 file() file information 4-122 fseek() set file position 4-130 ftell() file position 4-132 remove() remove system file 4-250 file() file information 4-122 floor() integer floor 4-124 fmod() floating point remainder 4-125 fopen() open file channel 4-126 foreach statement 3-11 fseek() set file position 4-130 ftell() file position 4-132 full_discovery() verify mode 4-134 function statement 3-13 Functions backward compatibility 3-19 entry point 3-17 limitations of user-defined 3-19 local variables 3-16 return statement 3-14 start of execution 3-18
globa lconstant propagation optimization C-13 global optimizations C-14 grep() match expression 4-150
H
here document 2-7 history() return history 4-152 history_get_retention() return retention value 4-155
I
I/O functions chart() load/destroy/print chart 4-35 log() record event 4-172 print() formatted output 4-208 printf() C output format 4-209 read() channel read 4-222 readln() read line 4-224 sprintf() print as string 4-378 tmpnam() temporary file name 4-398 write() write to channel 4-415 if statement 3-21 in_transition() allow state change 4-160 incompatibilities with C 6-8 increment/decrement operators 2-12 index() locate string 4-156 int() return integer 4-157 intermediate code (quad) optimizer tool C-10 internal() process internal to PATROL Agent 4-158 interpreted language 1-2 intersection() set intersection 4-159 is_var() verify variable 4-164 isnumber() verify expression 4-162
BMC Software, Inc., Confidential and Proprietary Information
G
get() get value 4-135 get_chan_info() channel status 4-136 get_ranges() return alarm range settings 4-144 get_vars() list variables 4-148 getenv() object environment 4-140 getpid() return process ID 4-142 getpname() get process name with pid 4-143
J
join() join strings together 4-165 jump chain reduction optimization C-12
K
kill() terminate PSL process 4-166
L
last statement 3-23 length() count characters 4-167 Level 1 optimizations C-12 Level 1 peephole optimization C-12 Level 2 local optimizations C-13 Level 3 global optimization C-14 lines() count lines 4-168 list values 2-8 local optimizations C-13 lock functions destroy_lock() destroy process lock 4-66 lock() request lock 4-169 lock() request lock 4-169 locking functions unlock() release lock 4-408 log() record event 4-172 log10() logarithm (10) 4-175 loge() logarithm (e) 4-173 logical operators 2-13 loop tail login injection optimization C-14 lvalues 2-3
atan() arctangent 4-20 ceil() integer ceiling 4-31 convert_base() convert base 4-47 cos() cosine 4-52 cosh() hyperbolic cosine 4-55 exp() e to a power 4-120 fabs() absolute value 4-121 floor() integer floor 4-124 fmod() floating point remainder 4-125 log10() logarithm 10 4-175 loge() logarithm (e) 4-173 pow() raise to a power 4-206 random() random numbers 4-220 sin() sine function 4-323 sinh() hyperbolic sine 4-325 sqrt() square root 4-383 srandom() seed random number 4-385 tan() tangent 4-393 tanh() hyperbolic tangent 4-395
N
name space, common 2-3 naming conventions, PSL 1-14 new-line character 2-6 next statement 3-24 ntharg() return text match 4-177 nthargf() return text match 4-180 nthline() return lines 4-183 nthlinef() return lines 4-185 num_consoles() number of registerd consoles 4-187 numeric functions 4-157
M
mathematical functions acos() arccosine 4-8 asin() arcsine 4-19
BMC Software, Inc., Confidential and Proprietary Information
O
object function exists() verify object 4-118 object functions 4-47, 4-57
Index
blackout() hide state changes 4-24 change_state() change object state 4-33 destroy() destroy object 4-65 get() get value 4-135 get_vars() list variables 4-148 getenv() object environment 4-140 is_var() verify variable 4-164 set() set variable 4-316 sort() sort list 4-375 unset() remove set() object 4-410 object state 4-34 operators, PSL 2-10 optimization 1-3 optimization levels C-12, C-13, C-14 orphan block inlining optimization C-15
P
parameter built-in Agent namespace variables B-6 parameter functions annotate() annotate parameter value 4-9 annotate_get() return parameter annotation 4-14 get_ranges() return alarm range settings 4-144 refresh_parameters() execute PATROL parameters 4-226 parameter history functions dump_hist() history data 4-69 history() return history 4-152 history_get_retention() return retention value 4-155 parameter ordering optimization C-14 parameter packing optimization C-12 PATROL Agent functions pconfig() configurre PATROL Agent 4-189 PATROL Console functions
console_type() identify PATROL Developer Console 4-46 num_consoles() number of registered consoles 4-187 response() create dialog 4-253 PATROL Script Host ActiveX 2-8 pconfig() configure PATROL Agent 4-189 peephole optimization C-12 pitfalls, PSL 6-8 popen() process channel 4-201 popup_report() popup task window 4-203 pow() raise to a power 4-206 ppv tool C-3, C-8 print() formatted output 4-208 printf() C output format 4-209 proc_exists() verify process 4-213 process control functions atexit() call at end of process 4-22 getpid() return process ID 4-142 getpname() get process name 4-143 kill() terminate PSL process 4-166 PslExecute() start PSL process 4-217 PslSetOptions() set run-time options 4-219 sleep() suspend process 4-327 trace_psl_process() enable tracing 4-401 process() process status 4-214 ProfDefaultOptions C-6 ProfDefaultOptions() function C-6 ProfGet() function C-6 ProfGetTotalCpu() function C-6 Profiler API C-3 Profiler tool C-2 Profiler Viewer tool C-3 -profiling option C-5, C-9 ProfOptions() function C-7 ProfReset() function C-7 ProfTop() function C-7 PSL
BMC Software, Inc., Confidential and Proprietary Information
additional tools C-1 common coding errors 6-10 compiler warnings 6-14 data types 2-2 errors, diagnosing 6-1 here document 2-7 incompatibilities with C 6-8 operators 2-10 pitfalls 6-8 runtime error messages 6-17 statements 3-2 style guidelines 1-14 psl - PSL compiler 5-8 PSL Optimizer tool command line options C-17 PSL Profile Viewer (ppv) Tool C-8 PSL Profiler API C-3 PSL Profiler functions C-3 PSL Profiler tool C-2 limitations C-4 with PATROL v3.1 C-3 PSL Profiler Viewer (ppv) tool C-3 PslDebug variable 6-2 PslExecute() start PSL process 4-217 PslSetOptions() set run-time options 4-219
Q
quad optimizer tool C-10
R
random() random numbers 4-220 read() channel read 4-222 readln() read line 4-224 redundant instruction removal optimization C-12 refresh_parameters() execute PATROL parameters 4-226
BMC Software, Inc., Confidential and Proprietary Information
relational operators 2-14 relative address 1-12 release notes xix remote functions remote_close() end remote agent session 4-228 remote_event_query() return remote agent events 4-229 remote_event_trigger() create remote agent event 4-235 remote_file_send() copy file to remote agent 4-237 remote_open() open remote agent session 4-242 remote_close() end remote agent session 4-228 remote_event_query() return remote agent events 4-229 remote_event_trigger() create remote agent event 4-235 remote_file_send() copy file to remote agent 4-237 remote_open() open remote agent session 4-242 remove() remove system file 4-250 replace() replace string in text 4-252 requires statement 3-25 response() create dialog 4-253 compound element nesting 4-293 compound element summary 4-292 control field summary 4-291 field formats 4-291 check boxes 4-262 column compound element 4-267 frame compound element 4-268 icon 4-270 label 4-272 option menu 4-273 popup compound element 4-274 preferences 4-255
Index
radio button 4-277 response() high-level 4-253 row compound element 4-280 scrolled list 4-281 separator 4-284 sliding scale 4-285 text field 4-287 toggle button 4-290 return value formats 4-297 response_get_value() return dynamic dialog status 4-311 rindex() last occurrence 4-314 root directory 1-12 rule state 4-34 run-time error checking 6-2 run-time error messages 6-17 runtime error messages 6-17
S
scalar 2-2 scripts ActiveX 2-8 set functions difference() unique to set 4-67 intersection() set intersection 4-159 subset() verify subset 4-386 union() merge lists 4-405 unique() remove duplicate elements 4-407 set() set variable 4-316 share() make global channel 4-321 share() share channel KM developer notes 4-322 simple expressions 2-9 sin() sine function 4-323 sinh() hyperbolic sine 4-325 sleep() suspend process 4-327 SNMP functions
snmp_agent_config() configure SNMP agent 4-329 snmp_agent_start() start SNMP agent 4-331 snmp_agent_stop() stop SNMP agent 4-332 snmp_close() close SNMP session 4-333 snmp_config() configure SNMP session 4-335 snmp_get() return MIB variables 4-341 snmp_get_next() get next MIB variable 4-343 snmp_h_get() get MIB variable fast 4-345 snmp_h_get_next() return next variable fast 4-348 snmp_h_set() set MIB variables fast 4-351 snmp_open() open SNMP session 4-354 snmp_send_trap() send SNMP trap 4-371 snmp_set() set MIB variables 4-356 snmp_trap_ignore() ignore SNMP traps 4-359 snmp_trap_listen() accumulate SNMP traps 4-360 snmp_trap_raise_std_trap() raise PATROL trap 4-363 snmp_trap_receive() receive SNMP traps 4-364 snmp_trap_register_im() PATROL trap receiver list 4-368 snmp_walk() subsequent MIB variables 4-373 snmp_agent_config() configure SNMP agent 4-329 snmp_agent_start() start SNMP agent 4-331 snmp_agent_stop() stop SNMP agent 4-332 snmp_close() close SNMP session 4-333
BMC Software, Inc., Confidential and Proprietary Information
10
snmp_config() configure SNMP session 4-335 _snmp_debug() start SNMP debugging 4-339 built-in functions _snmp_debug() start SNMP debugging 4-339 SNMP functions _snmp_debug() start SNMP debugging 4-339 snmp_get() return MIB variables 4-341 snmp_get_next() get next MIB variable 4-343 snmp_h_get() get MIB variable fast 4-345 snmp_h_get_next() return next variable fast 4-348 snmp_h_set() set MIB variables fast 4-351 snmp_open() open SNMP session 4-354 snmp_set() set MIB variables 4-356 snmp_trap_ignore() ignore SNMP traps 4-359 snmp_trap_listen() accumulate SNMP traps 4-360 snmp_trap_raise_std_trap() raise PATROL trap 4-363 snmp_trap_receive() receive SNMP traps 4-364 snmp_trap_register_im() PATROL trap receiver list 4-368 snmp_trap_send() send SNMP trap 4-371 snmp_walk() subsequent MIB variables 4-373 sort() sort list 4-375 sprintf() print as string 4-378 sqrt() square root 4-383 srandom() seed random number 4-385 state 4-34 statement block 3-2 Statements do...until 3-4
BMC Software, Inc., Confidential and Proprietary Information
exit 3-6 export 3-7 foreach 3-11 function 3-13 if 3-21 last 3-23 next 3-24 requires 3-25 switch 3-27 while 3-33 string concatenation conversion optimization C-14 string functions encrypt() encrypt a string 4-73 grep() match expression 4-150 index() locate string 4-156 isnumber() verify expression 4-162 join() join strings together 4-165 length() count characters 4-167 lines() count lines 4-168 ntharg() return text match 4-177 nthargf() return text match 4-180 nthline() return lines 4-183 nthlinef() return lines 4-185 replace() replace string in text 4-252 rindex() last occurrence 4-314 substr() return substring 4-388 tail() last text lines 4-391 tolower() all lower case 4-399 toupper() all upper case 4-400 trim() remove characters 4-403 string literals 2-6 string operators 2-15 strings here document 2-7 string literals 2-6 subset() verify subset 4-386 substr() return substring 4-388 switch statement 3-27 system() submit command 4-389
Index
11
T
tab character 2-6 tail() last text lines 4-391 tan() tangent 4-393 tanh() hyperbolic tangent 4-395 time functions asctime() date/time 4-16 convert_date() return system time 4-49 date() date/time 4-62 time() seconds since 01/01/70 4-397 time() seconds since 01/01/70 4-397 tmpnam() temporary file name 4-398 tolower() all lower case 4-399 tools C-1 toupper() all upper case 4-400 trace_psl_process() enable tracing 4-401 trim() remove characters 4-403
W
while statement 3-33 write() write to channel 4-415
U
union() merge lists 4-405 unique() remove duplicate elements 4-407 unlock() release lock 4-408 unreachable code removal optimization C-14 unset() remove set() object 4-410 useless jump removal optimization C-12 user commands 1-10 user-defined variables 1-13
V
va_arg() return next argument 4-411 va_start() reset argument list 4-413 variable argument functions va_arg() return next argument 4-411 va_start() reset argument list 4-413
BMC Software, Inc., Confidential and Proprietary Information
12