Maple Professional
Maple Academic
Maple Student Edition
Maple Personal Edition
Maple Player
Maple Player for iPad
MapleSim Professional
MapleSim Academic
Maple T.A. - Testing & Assessment
Maple T.A. MAA Placement Test Suite
Möbius - Online Courseware
Machine Design / Industrial Automation
Aerospace
Vehicle Engineering
Robotics
Power Industries
System Simulation and Analysis
Model development for HIL
Plant Modeling for Control Design
Robotics/Motion Control/Mechatronics
Other Application Areas
Mathematics Education
Engineering Education
High Schools & Two-Year Colleges
Testing & Assessment
Students
Financial Modeling
Operations Research
High Performance Computing
Physics
Live Webinars
Recorded Webinars
Upcoming Events
MaplePrimes
Maplesoft Blog
Maplesoft Membership
Maple Ambassador Program
MapleCloud
Technical Whitepapers
E-Mail Newsletters
Maple Books
Math Matters
Application Center
MapleSim Model Gallery
User Case Studies
Exploring Engineering Fundamentals
Teaching Concepts with Maple
Maplesoft Welcome Center
Teacher Resource Center
Student Help Center
type/module - check for a module
type/record - check for a record
Calling Sequence
type(expr, '`module`')
type(expr, '`module`'(e1, e2, ..., en))
type(expr, 'record')
type(expr, 'record'(e1, e2, ..., en))
Parameters
expr
-
any expression
ei
names of expected exports
Description
The command type(expr, '`module`') returns true if expr is of type module. Otherwise, false is returned.
Expressions of type module are created as a result of evaluating a module definition.
When called with optional arguments ei (), the command returns true if, in addition to being of type module, the module e exports members named e1, e2, ..., en. It is not required that e1, e2, ..., en name all the exports of the module, only that each among them appears as an export. (Note carefully the type and placement of quotes in the Examples section below.)
The optional exports ei can be either symbols or expressions of the form symbol :: type. If a type specifier appears, then the module expr must export the given name with an assigned value of the given type. For instance, the type `module`( x :: posint ) describes a module with an export named x currently assigned a value of type posint.
The first optional export, e1, can also be a string. In that case, the module expr must be a named module whose name matches (textually) e1.
Note: Because the name module is a Maple keyword, it must be enclosed in back quotes when used as an argument to type. Failure to do so results in a syntax error.
The type record is identical to type module, except that it recognizes modules that are records, returning false for modules that are not records. (See Record.)
Examples
p := proc(x) local XYZ; module XYZ() export a; end module; XYZ:-a := x; XYZ end proc:
See Also
module, Record, type, type/moduledefinition
Download Help Document