Control File Placement of Custom Data Types
By default, when you use data type objects, such as Simulink.AliasType and
                Simulink.Bus, and custom enumerations to specify data types for
            signals and block parameters, the code generated from the model defines the types (for
            example, with typedef statements). To ease integration of the
            generated code with other existing code and to modularize the generated code, you can
            control the file placement of the type definitions by adjusting the properties of the
            objects and the enumerations.
Data Scope and Header File
To control the file placement of a custom type definition in generated code, set
                the DataScope and HeaderFile properties of the
                data type object according to the table. Similarly, for an enumeration that you
                define in a MATLAB® file, set the return arguments of the
                    getDataScope and getHeaderFile
                methods.
- typename
- filename
- model
| Goal | Specify DataScopeas | Specify HeaderFileas | 
|---|---|---|
| Export type definition to  | Auto | Empty | 
| Import type definition from a header file that you create,  | AutoorImported | (if
                                necessary, include a.hextension) | 
| Export type definition to a generated header file,  | Exported | or | 
| Export type definition to a generated header file,  | Exported | Empty | 
When you import a data type definition (for example, by setting
                    DataScope to Imported), the generated
                model code creates an #include directive for your header file in
                place of a type definition. You supply the header file that contains the definition.
                To avoid linker errors, you must add include guards, such as #pragma
                    once, to the beginning of an imported header file.
Note
When you set the HeaderFile property, these characters are
                    not supported:
- *
- ?
These characters are supported ONLY when used as a leading or trailing delimiter:
- "— For example,- "abc.h"is supported, but- ab"c.his not.
- <and- >— For example,- <abc.h>is supported, but- a>bc.his not.
Considerations for Data Type Replacement
- If you use the Specify custom data type names configuration parameter to replace a built-in Simulink® Coder™ data type with your own data type in generated code (see Model Configuration Parameters: Code Generation Data Type Replacement), - typedefstatements and- #includedirectives appear in- rtwtypes.hinstead of- model_types.h
- When you use a - Simulink.AliasTypeor- Simulink.NumericTypeobject in data type replacement, you cannot set the- DataScopeproperty of the object to- Exported. Therefore, if you want the code generator to generate the corresponding- typedefstatement, you cannot control the file placement of the statement. However, you can set- DataScopeto- Imported, which means that you can configure the code to reuse the- typedefstatement that your external code provides.- As a workaround, instead of using the data type object as a data type replacement, use the object to set the data types of individual data items in a model. To configure many data items, you can use the Model Data Editor and take advantage of data type propagation and inheritance. For more information, see Specify Custom Names Using Data Replacement Type Pane. 
Import Definition of Numerically Complex Data Type
You can use a Simulink.AliasType object with numerically
                    complex data (i). In this case, if you configure the
                    generated code to import the type definition from your external code (for
                    example, by setting the DataScope property to
                        Imported), your code must provide two complementary
                        typedef statements.
Suppose your external header file myAliasTypes.h defines
                    the data type IAT_int32 as an alias of a 32-bit integer. The
                    file must define two types: IAT_int32 and
                        cIAT_int32:
#ifndef myAliasTypes_H_ #define myAliasTypes_H_ #include "rtwtypes.h" typedef int32_T IAT_int32; typedef cint32_T cIAT_int32; #endif
You do not need to create two Simulink.AliasType objects. In
                    this example, you create one object, IAT_int32. The generated
                    code then creates complex data (variables) by using both
                        IAT_int32 and cIAT_int32.
Macro Guards
When you export one or more data type definitions to a generated header file, the
                file contains a file-level macro guard of the form
                        RTW_HEADER_. filename_h
Suppose that you use several Simulink.AliasType objects:
                    mySingleAlias, myDoubleAlias, and
                    myIntAlias with these properties:
- DataScopeset to- Exported
- HeaderFileset to- myTypes.h
When you generate code, the guarded file myTypes.h contains the
                    typedef statements:
#ifndef RTW_HEADER_myTypes_h_ #define RTW_HEADER_myTypes_h_ #include "rtwtypes.h" typedef real_T myDoubleAlias; typedef real32_T mySingleAlias; typedef int16_T myIntAlias; #endif
When you export data type definitions to
                    model_types.h_DEFINED_TYPEDEF_FOR_
                for each typename_typedef statement. Suppose that you use a
                    Simulink.AliasType object mySingleAlias
                with these properties:
- DataScopeset to- Auto
- HeaderFilenot specified
When you generate code, the file
                    model_types.htypedef statement:
#ifndef _DEFINED_TYPEDEF_FOR_mySingleAlias_ #define _DEFINED_TYPEDEF_FOR_mySingleAlias_ typedef real32_T mySingleAlias; #endif
See Also
Simulink.AliasType | Simulink.NumericType | Simulink.Bus