Tech Note 37: Using the DevInfoLib Shared Library

July 15, 2005

 

Copyright 2005 Douglas Handy


This library was contributed by Douglas Handy.

Contents:

    Introduction
    Function Index and Quick Reference
    Function Reference

Introduction:

This library provides some basic information on the device on which it is running.

In order to use the DevInfoLib Shared Library, the library must be loaded using the NSBasic LoadLibrary statement. This statement should be located in the program's Startup code so that the functions will be available throughout the program. The LoadLibrary statement has an optional second parameter to allow you to specify an abbreviated reference name for the library's functions. The examples in this document use "Dev" for this reference name. Example:

Program's Startup code:

	Sub main()
	    LoadLibrary "DevInfoLib", "Dev"
	End Sub

Also, in order to use the DevInfoLib Shared Library, the Dev.INF file must be present in your "nsbasic\lib" directory and the Dev.prc file must be added to your project as a resource with a type of "libr".

All the parameter and return data types are either "Integer" or "String".

Function Index and Quick Reference:


Device Information
    CompanyID          ID = CompanyID()
    DeviceID           ID = DeviceID()
    HALid              ID = HALid()
    HwrMiscFlags       Flags = HwrMiscFlags()
    ProcessorID        ID = ProcessorID()
    GetSystemFeature   value = GetSystemFeature(ftr)
    GetFeature         value = GetFeature(creator, ftr)
    SetFeature         SetFeature creator, ftr, value
    GetBitValue        result = GetBitValue(intValue, bitNumber)
    SetBitValue        result = SetBitValue(intValue, bitNumber, bitValue)
    GetSerialNumber    SerialID = GetSerialNumber(AddCheckDigit)
    HotSyncUserName    HSUserName = HotSyncUserName()
    HotSyncUserID      HSUserID = HotSyncUserID()
    BatteryKind        Kind = BatteryKind()
    BatteryPct         Pct = BatteryPct()
    BatteryVolts       Volts = BatteryVolts()
    IsPluggedIn        State = IsPluggedIn()
    IsDocked           State = IsDocked()

DevInfoLib Function Reference:

Device Information

The device information functions provide information about the current device.

CompanyID

	ID = Dev.CompanyID()
Returns the company ID of the device manufacturer. This is a 4-byte code, as opposed to the name of the vendor. Common examples are "palm", "sony", "hspr", "grmn", or "Tpwv".
Returns:
	ID as String
Example:
	Dim ID as String

	ID = Dev.CompanyID()
If the code does not begin with a readable ASII character, an 8-byte string will be returned instead with the hexadecimal equivalent of the ID.

DeviceID

	ID = Dev.DeviceID()
Returns the device ID assigned by the device manufacturer. This is a 4-byte code, as opposed to the actual model name. Tables of common models can be found by searching the internet. One such list may be available at the following address: http://www.mobilegeographics.com/dev/devices.php
Returns:
	ID as String
Example:
	Dim ID as String

	ID = Dev.DeviceID()
If the code does not begin with a readable ASII character, an 8-byte string will be returned instead with the hexadecimal equivalent of the ID.

HALid

	ID = Dev.HALid()
Returns the "HAL" ID assigned by the device manufacturer. HAL stands for Hardware Abstraction Layer. It is returned as a 4-byte string value, when it contains a readable mneumonic value.
Returns:
	ID as String
Example:
	Dim ID as String

	ID = Dev.HALid()
If the code does not begin with a readable ASII character, an 8-byte string will be returned instead with the hexadecimal equivalent of the ID.

HwrMiscFlags

	Flags = Dev.HwrMiscFlags()
Returns an integer with hardware flags defined by the vendor. It may be useful to help distinguish between various models within some product lines. See aso DeviceID().
Returns:
	Flags as Integer
Example:
	Dim Flags as Integer

	Flags = Dev.HwrMiscFlags()
Unlike CompanyID() and DeviceID(), this is returned as an integer value instead of a string. This makes it useful to pass to BitValue() to check the status of individual bits.

ProcessorID

	ID = Dev.ProcessorID()
Returns an integer representing what type of processor is used in the device.
Returns:
	ID as Integer
	       Processor types include:
Example:
	Dim ID as Integer

	ID = Dev.ProcessorID()

GetSystemFeature

	value = Dev.GetSystemFeature(ftr)
Returns an integer with the contents of a specific system "feature" code.
Parameter:
	ftr as Integer
	       System feature number requested.
Returns:
	value as Integer
	       System feature value, or 0 if the feature does not exist.
Example:
	Dim value as Integer
	Dim ftr as Integer

	value = Dev.GetSystemFeature(ftr)
System feature numbers are documented in SystemMgr.h within the Palm OS SDK. The returned value may be passed to BitValue() to obtain the status of an individual bit.

GetFeature

	value = Dev.GetFeature(creator, ftr)
Returns an integer with the contents of any feature code set by any application. When used with creator ID "psys", it is the equivalent of calling GetSystemFeature() above.
Parameters:
	creator as String
	       Creator ID of the feature number requested.
	ftr as Integer
	       Feature number requested (0-32767)
Returns:
	value as Integer
	       Feature value, or 0 if the feature does not exist.
Example:
	Dim value as Integer
	Dim creator as String
	Dim ftr as Integer

	value = Dev.GetFeature(creator, ftr)
Feature values are used by some ROM based applications, and may be set by user applications as well. See SetFeature().

SetFeature

	Dev.SetFeature creator, ftr, value
Stores an integer value as a "feature" code under Palm OS. Features are a fast way to store integers which survive across invocations of a program. That is, they are like a global variable which can be recalled the next time the program is run. However, they do NOT survive a soft reset.
Parameters:
	creator as String
	       Creator ID associated with the feature.  It is recommended

	       to use your own application's creator ID for this.

	ftr as Integer
	       Feature number (0-32767)

	value as Integer
Example:
	Dim creator as String
	Dim ftr as Integer
	Dim value as Integer

	Dev.SetFeature creator, ftr, value
See also SetBitValue() to control individual bits of value.

GetBitValue

	result = Dev.GetBitValue(intValue, bitNumber)
Returns 1 if the specified bit number is 1, otherwise it returns 0.
Parameters:
	intValue as Integer
	       Bit to test; bits are numbered from right to left from 0 to 31.
	bitNumber as Integer
Returns:
	result as Integer
Example:
	Dim result as Integer
	Dim intValue as Integer
	Dim bitNumber as Integer

	result = Dev.GetBitValue(intValue, bitNumber)
BitValue() can be useful for analyzing values returned by such calls as HwrMiscFlags(), GetSystemFeature(), etc.

SetBitValue

	result = Dev.SetBitValue(intValue, bitNumber, bitValue)
Sets the bit specified by bitNumber to the specified bit value.
Parameters:
	intValue as Integer
	       Original integer value, before bit is changed.
	bitNumber as Integer
	       Bit to set; bits are numbered from right to left from 0 to 31.
	bitValue as Integer
	       New bit value (0 = off, 1 = on)
Returns:
	result as Integer
	       New integer value after changing the requested bit.
Example:
	Dim result as Integer
	Dim intValue as Integer
	Dim bitNumber as Integer
	Dim bitValue as Integer

	result = Dev.SetBitValue(intValue, bitNumber, bitValue)
This call may be useful with SetFeature().

GetSerialNumber

	SerialID = Dev.GetSerialNumber(AddCheckDigit)
Returns the device ROM serial number, if any, and optionally the check digit suffix. This value corresponds to the value display using the default app launcher Info menu on the Version tab, and appears just below the OS version. bit value.
Parameter:
	AddCheckDigit as Integer
	       Specify 0 to exclude the check digit; 1 to include the check digit.
Returns:
	SerialID as String
	       Serial number of device, when available.
Example:
	Dim SerialID as String
	Dim AddCheckDigit as Integer

	SerialID = Dev.GetSerialNumber(AddCheckDigit)
Many common devices do not have a ROM serial number, and no amount of wishing will make it so. Serial numbers will be a 12 byte string without the check digit, and a 14 byte string if the suffix is included (where byte 13 is a hyphen as shown by the app launcher Info menu item).

HotSyncUserName

	HSUserName = Dev.HotSyncUserName()
Returns the HotSync user name.
Returns:
	HSUserName as String
Example:
	Dim HSUserName as String

	HSUserName = Dev.HotSyncUserName()
If Hot Sync has never been run, or after a hard reset, this returns an empty string.

HotSyncUserID

	HSUserID = Dev.HotSyncUserID()
Returns the HotSync user ID number.
Returns:
	HSUserID as Integer
Example:
	Dim HSUserID as Integer

	HSUserID = Dev.HotSyncUserID()
The user ID number is a pseudo-random number assigned by Hot Sync to help warn against using two devices with the same user name on a given PC. Such can result in co-mingling or loss of data, so to help avoid it an ID number is assigned and compared with the desktop.

BatteryKind

	Kind = Dev.BatteryKind()
Returns the type of battery installed on the device.
Returns:
	Kind as Integer
	       One of the following values:
	         0 = Alkaline
	         1 = NiCad
	         2 = LiIon
	         3 = Rechargeable Alkaline
	         4 = NiMH
	         5 = LiIon, 1400mah
Example:
	Dim Kind as Integer

	Kind = Dev.BatteryKind()

BatteryPct

	Pct = Dev.BatteryPct()
Returns the approximate percentage of battery life remaining.
Returns:
	Pct as Integer
Example:
	Dim Pct as Integer

	Pct = Dev.BatteryPct()
This figure is an approximation. Palm OS will issue warnings when the percentage drops to a certain level, and entirely force the unit off when critically low in order to attempt to preserve memory contents until the batteries are replaced.

BatteryVolts

	Volts = Dev.BatteryVolts()
Returns the current battery voltage multipled by 100. For example, 3.02 volts is returned as 302.
Returns:
	Volts as Integer
Example:
	Dim Volts as Integer

	Volts = Dev.BatteryVolts()

IsPluggedIn

	State = Dev.IsPluggedIn()
For rechargeable units, indicates if it is currently plugged in.
Returns:
	State as Integer
	       0 = not plugged in; 1 = plugged in
Example:
	Dim State as Integer

	State = Dev.IsPluggedIn()
The device may or may not also be in a cradle, or even if in a cradle it may not have power supplied. See also IsDocked().

IsDocked

	State = Dev.IsDocked()
Indicates if device is currently docked to a desktop.
Returns:
	State as Integer
	       0 = not docked; 1 = docked via cradle or cable
Example:
	Dim State as Integer

	State = Dev.IsDocked()
The device may or may not also be recharging. See also IsPluggedIn() above. Some units do not support detecting whether or not they are currently docked.