sap odata mpc_ext define. SAP List Report-Selection Mandatory with default value. sap odata mpc_ext define

 
 SAP List Report-Selection Mandatory with default valuesap odata mpc_ext define  Calling expand entity from SAP Gateway Client

So now that we have had a brief primer on Fiori Elements and SAP and vocabulary-based annotations in OData, it is time to put. Right click on the Data Model folder and select Redefine OData Service (SAP GW) from the context menu. Further we are going to write logic in MPC_EXT class for creating annotations. In terms of annotation. Create the corresponding association set explicitly by calling /IWBEP/IF_MGW_ODATA_MODEL->CREATE_ASSOCIATION_SET. The MPC includes the MPC of the source service, and the DPC inherits the DPC of the source service. v1. Created OData ‘ZTEST_SEARCHHElP’. A service can be called an API that SAP provides to their consumers. Click on Assign OData Service button. Click on Icon Create. Import the entity type properties from the dictionary structure if not done during entity type creation. Annotations can be added in the MPC_EXT class using the following steps:Introduction. I implemented some CDS views with associations on a SAP NETWEAVER 7. While writing the ODATA service, normally we follow the below steps in Model class. And in the end there is a COPY_DATA_TO_REF ( EXPORTING IS_DATA = LS_STREAM CHANGING CR_DATA = ER_STREAM) – Kirve. In SAP terms, Odata a platform/framework that can be used to create SAP objects or services that can be consumed from outside of SAP box to read or write data. create two CDS views based on the. ODATA Service can be used freely without license or Contract. " Example of material entity type definition for json data mapping, entity found by key TYPES BEGIN OF type_json_resp_material. On pressing F4 we will get a Popup of value help with empty list. Here the property can be handled by redefining the DEFINE method of MPC_EXT class of the ODataNavigation-1 – HeadItemO. 4. List of demo programs in SAP which explains SAP ALV Drag Drop functionality. To explicitly define which field groups you want to display in the Adapt Filters dialog, use the UI. Property element SAP Odata V2 annotation at property level that tells the property should be. Redefine method GET_ENTITYSET of Data. The trick is basically the the get_entityset method in the DPC_EXT class is redefined and manipulates the navigation Information that is passed to the SADL Framework before it is calling the SADL implementation in the super class. In this case “Z_JW_BUSPARTNER”. Rule 5. Dec 19, 2021 at 13:41. If we implement any code in DPC/MPC while generating runtime object the code gets deleted. Using reference on ABAP CDS. We can then fetch data using get_entityset method of DPC_EXT class. This is one of most frequent scenario where the text of key-value is stored in a text table. You can append new properties to a corresponding entity type in the data model redefinition. super->define( ) . As evident from the heading am not able to debug DPX_EXT methods because of External Breakpoints not triggering. You can use it to send batch requests, define functions for reusable procedures, and discover changes, among other things. Value Help Entity: Customer Value Help. Step 1. using table and structure list below with Project Details. The actual SAP Gateway service object named <CDS_VIEW_NAME>_CDS (R3TR IWSV obj) An SAP Gateway model named <CDS_VIEW_NAME>_MDL (R3TR IWMO obj) An annotation model named <CDS_VIEW_NAME>_CDS_VAN (R3TR IWVB obj) So no DPC/MPC_EXT classes are created, if you need OData methods redefinition you. SAP Editable ALV Grid Sample Code. Go to the Types and declare a type: types: BEGIN OF ts_deep_entity. In the Select Service region, enter the technical name of the service you wish to redefine in the Technical Service Name field. 2. Direction: drag from tree and drop in ALV control. CDS View: Annotation. Then I have also tried adding custom property directly in CDS entity type 'C_MaintOrderComponentTPType' in Method define of MPC_EXT class using below code. Now, We are all set to do UI Development. Below is the architecture of ABAP RESTful Application Programming Model to develop Odata services. DATA: lo_ann_target TYPE REF TO /iwbep/if_mgw_vocan_ann_target. For OData version 4. ), custom query options (extensibility mechanism, used eg. I tried to add annotations using the 'XXXXX_MPC_EXT' object. Typically if we are using a SAP Gateway hosted OData service this includes: A service metadata xml generated by SAP Gateway; The annotations assigned to the OData Service itself; On the Template Customization tab, we select the OData Collection (i. In MPC_EXT we have to specify the semantic attribute of our. Vote up 1 Vote down. Model for SAP Fiori OData V2 service development options –SAP BS 7 & SAP S/4HANA Classic DDIC tables OData V2 BOPF BO CDS views Query Engine Classic CDS views business logic Query Engine Code based implementation Brownfield Greenfield DDIC tables Service Builder (SEGW) Service Builder (SEGW) Referenced / Mapped Data Source. You can copy the class code in source code based view of SE24. Deep Insert oData Steps: Go to T-Code “SEGW” (ECC Server). Dec 19, 2021 at 13:41. Enter Change Mode, Select ‘Define’. Example 5: Setting a Date Range Filter. protected section. sap:display-format =” Date “ sap:filter-restriction =” interval “ For setting these annotations you can write the below code in MPC_EXT class, DEFINE method. Then, create the deep structure & activate. publish: true define view Z_Products as select from Products { key Products. MPC – This is used to define model. Generated MPC classes also supports inline annotations if annotations are maintained in the model. Label,. Save and generate. Mahesh Palavalli Jun 21, 2019 at 11:11 AM Dpc_ext class will be called everytime you send a request to the odata service. Use then lo_property->SET_AS_CONTENT_TYPE. 1. to a property of an entity of this service? In SEGW-based OData service, we can do this by selecting the checkboxes or by redefining method. Its available SAP Cloud Platform and also on-premise from S4HANA 1909. 2. Our view is now ready. Specify template id and name, which will then appear in Custom tab. DATA: lo_annotation TYPE REF TO /iwbep/if_mgw_vocan_annotation. METHOD define. Create one header database table as root, and another database table as item. [5. And i am executing the method from gateway client but my DPC_EXT class redefined method is not called and it is calling original method . Entity Type 4 – ord_opr. 1] Re-define MPC. Your data model is based on CDS, but is more complex than simple compositions and includes advanced features, such as transactional processing. e. An entry will be created as below. SAP Fiori Inbox extension is a common extension scenario in most of the S/4 HANA Projects . I cleared cache , deleted the service n added back. Now in WebIDE – Lets select redefined service. soid is of type Edm. From the Analytical List report Fiori element documentation I got to know this type of application only works for analytical(?) and the OData service should have some specific annotations like - "aggregate" and "sap:aggregation-role=dimension/measure". In the method GET_EXPANDED_ENTITY, the value getting passed to the structure er_entity. Open the Define_Entity Name Method in either the _MPC_EXT or _MPC from the Runtime Artifacts folder and check if the following code snippet is available. Select the entity type “ZFILE” you just created and Choose the check box media as selected. Implementation of SAP Odata V4. These methods of the DPC must not be. These steps cover the general procedure, but need some consideration for your own SAP OData system and your preferred techniques for configuring SAP. To prevent that the get_entityset method is getting called you have to fill your techclause e. Select, filter,. Choose menu Overview->Imports. I liked this one Deep Insert in SAP Netweaver Gateway from Prakash’s blog series. Start transaction SE63. Your data model is based on CDS, but is more complex than simple compositions and includes advanced features, such as transactional processing. Collection of code snippets which I regularly use in MPC_EXT DEFINE method. 16 28 49,455. First, we define CDS view based on table TCURT with language, key and text fields from it. Naveen on How to upload Excel to SAP(using ABAP) Upamanyu Sarmah on S4 HANA Output Management – Introduction, Master Form Layout Edit and Setup; Pankaj on SAPScript symbols and formatting options; Mary Roopini A on SEGW – OData MPC_EXT-DEFINE Code Collection; Mary Roopini A on SEGW – OData MPC_EXT. This blog will show you how to develop ODATA using Global Classes in CREATE_DEEP_ENTITY Method Operation with JSON Format using simple steps. Let’s start by showing you, on which Function Import I will based my post. DATA: lo_annotation TYPE REF TO /iwbep/if_mgw_odata_annotation, lo_entity_type TYPE REF TO. super->define ( ). String with a length of 10) and Description (Edm. RajeshDescribed about the Define( ) method and its properties like when to trigger, what kind of code got generated in the method, and when we need to redefine thi. Like this: TreeTable but the problem here is data is appearing in a list like manner since we don't have "edmanno soid is of type Edm. For each of the artifacts created, one method is generated and is called inside this method. These steps cover the general procedure, but need some consideration for your own SAP OData system and your preferred techniques for configuring SAP. From this list we can select required commodity code. Select the function module you use for uploading files. Then I use that ODATA service in a. 11. 2. METHOD define . These steps cover the general procedure, but need some consideration for your own SAP OData system and your preferred techniques for configuring SAP. In the pop up, enter a package assignment and accept the defaults and press the check box. METHOD define. This is important because its DPC_EXT and MPC_EXT classes which we will be using to add actions. Now click ‘Save’ and ‘Generate Runtime Objects’. This is the action that is called by the analytic application. Create 6 entity types and entity sets. Go to your Service’s MPC_EXT class and redefine your DEFINE method. Redefine Define method. I used in the SEGW transaction the reference by data source feature to automatically create the ODATA types and associations from the CDS views and add them to a existing SEGW ODATA project. 40 18 52,052. description is of type Edm. Firstly, we will see CDS annotations required to mimic this basic Object Page facets. Usually, you would copy email template by selecting pre-delivered template and using Copy button. You want to modify the service with custom code implementations. Entity Type 5 – mpos. I have been checking format possibilities in SEGW and I have learnt to apply ALPHA format to some of my fields in MDP_EXT class but I cannot find the way to apply the decimal notation format to numbers. method define. Redefine method Define of model provider class as shown below: 3. Any suggestions? Property type valdt - Edm. To register similar OData Service:Press the 'Refresh' button to the right of 'Metadata' section. Define condition from ValueHelp odata. METHODS define REDEFINITION. In this blog, I will go through the steps necessary to connect a SAP Master Data Integration service instance with a SAP S/4HANA On-premise system. There is some data dexlarations and read and select queries. It is also extensible which allows to add data types from ABAP Dictionary. In this blog I will explain how to use this class. In this example we are making a field as required by using Odata annotations. Insert field and check as key field (mandatory). This method will have two. I' ve created a GW service based on a DDIC structure, implemented the GET_ENTITYSET and GET_ENTITY method of _DPC_EXT class and redefined the DEFINE method of _MPC_EXT class. METHODS: define REDEFINITION. I have tried to replicate a similar operation through Flight Tables. Create Project in SEGW. The Service Builder allows you to redefine the OData services for SAP NetWeaver Gateway. Again, to get this Dynamic Date Picker on date field we need sap:filter-restriction=”interval” in metadata of the property. Mircosoft Power BI. Create a Gateway project: ZMEDIALNK_SB. To configure a well-defined SAP Gateway OData service, complete the following steps in your SAP system. To exclude your original column from showing in the Column tab of Table setting dialog, there is an annotation sap:visible = false. Pass the ValueHelp Entity in label and ValueHelp Entityset in CollectionPath. Refer. MPC is used to define model you can use the method Define create entity and properties. Model Provider class registers the metadata used in a service. 10. DATA : lv_namespace TYPE string, lr_annotation TYPE REF TO cl_fis_shlp_annotation, lr_annotation2 TYPE REF TO cl_fis_shlp_annotation. Navigate to Device Types tab and press Display next to Page Formats input. Below is the code that get the data for the 'Set' I need to change one of the fields for. OData PUT Call – DPC_EXT_UPDATE_ENTITY method SAP in a minute January 22, 2021 January 22, 2021 0. Here a sample code of how to set the entity EmployeePhoto to Stream in order to send Employee’s photo through SAP GW oData Service: ( source )Note : The structure for this purpose can also be created in MPC_EXT public section, I have created in SE11 for demonstrating the other possibilities. Step 1. Thanks. js’ file. is it also possible to set the annotation "sap:semantics: fixed-values" for the entity set directly in the CDS-View? I use the "OData. BCALV_DND_01 – Drag ALV Row to Tree Folder. Service Definition. The value of that attribute denotes the name of the currency (code) property that must be part of the same entity type. Posted on: January 14, 2019 &vert; By: Pawan Kesari – 1 Comment. If the class open in ‘Display’ mode than convert it to ‘Change’ mode. The Search help works fine in the Fiori App displaying the select options and showing the result list. In this class, you can choose which methods of the base class you want to keep and. Choose Reference –> Modeled Data Source Reference from the context menu. METHOD define . Create an entity ‘TEST’ with one dummy attribute (VBELN). Then I created a function import SetDescription with two parameters Salesorder (Edm. SAP OData is a standard Web protocol used for querying and updating data present in SAP using ABAP, applying and building on Web technologies such as HTTP to provide. Let us assume that we have any data table (probably in custom namespace, just to simplify demo case. g. When we change the Model or implement the Service in GW Service builder, every time run time object gets generated, hence DPC and MPC existing code gets replaced with new sets of code. For experiment, I created a service ( I'm on 7. Use this option if: The CDS model and the CDS annotations fully specify the OData Model and the runtime behavior. Generating an OData service via Referenced Data Source. g. 1. case when _konp. filter. 5 SP 19 (09/2020) system. Is it possible to add annotations like sap:nullable, sap:filterable etc. Figure 1. or /n/IWBEP/SB. 2. First, the name of the OData service. 1. Implementation. End Result –. You can regenerate the odata service. Let’s take this ahead with a step by step approach :-. In the table, enter the name of the OData service. · Use SEGW to extend the entity definition. In the MPC_EXT class of your service, overwrite the define method. Select the service DTINF_TC_MAINT_SRV . Select Create Project. The second version of the OData protocol allows you to add annotations to the metadata document; the purpose of the annotations is to add information and hints to the EDM elements. Flight Booking (Child) The application has been built with referring CDS views as data source. You can specify Email Template to used in Email Setting’s Determination Step. RSS Feed. Redefine. privacy statement, for purposes that may include site operation, analytics, enhanced user experience, or advertising. 2. There are various ways of creating configuration but the easiest way to create is via. The effect is the same as calling method BIND_STRUCTURE of interface /IWBEP/IF_MGW_ODATA_ENTITY_TYP . SAP OM configuration and technical implementation are totally different compared to traditional output technologies (NAST, FI Correspondence, FICA Print Workbench, sapscript, smartform, PDF. The UI5 app will recognize the SAP annotations and will render the tree table nicely. In addition, OData. INCLUDE TYPE workorder_structure. @OData. methods DEFINE: redefinition . But The static variable will only persist the incremented value only if there the soft state is activated else (makes sense) else it will always show the value ‘1’. This will give you list of all Page Formats defined in system, you can check this list to see if any of these matches your paper size. This report illustrates the simplest case of using an editable ALV Grid Control. commons. It is possible to create ABAP CDS view for it using SAP HANA Studio. It needs adding annotations from the odata service. In step 2 the referential constraints are provided. I have created an application with CDS as a data model. Right click on ZCL_ZTEST_MPC_EXT and select on Workbench option. DATA : lo_entity_type TYPE REF TO / iwbep / if_mgw_odata_entity_typ , lo_property TYPE REF TO / iwbep / if_mgw_odata_property . 3275 Views. 11. Extension of the Workflow container to fill in the extended fields using the BADI. This structural metadata makes it easy to understand a service, and human. Click on the Change ( Ctrl+F1) button for editing. r. Naveen on How to upload Excel to SAP(using ABAP) Upamanyu Sarmah on S4 HANA Output Management – Introduction, Master Form Layout Edit and Setup; Pankaj on SAPScript symbols and formatting options; Mary Roopini A on SEGW – OData MPC_EXT-DEFINE Code Collection; Mary Roopini A on SEGW – OData MPC_EXT. Then create an ABAP data element based on this domain. Introduction. Register the service ‘ZDEAL_DEMO’ generated using Transaction Code: /IWFND/MAINT_SERVICE. Odata mpc extension requirement. A CDS custom entity provides the signature of. So I am unable to know the structure and hence create a dynamic entity. Your data model is based on CDS, but is more complex than simple compositions and includes advanced features, such as transactional processing. Next step will show how to create an OData Mobile Data. super->define( ). Step 1. create a new complex type there. List of demo programs in SAP which explains SAP Editable ALV Grid. 1. ABAP Unit Test meets Legacy Code. For information on how value help annotations are set in CDS, see the SAP NetWeaver documentation UI Annotations. Note Generation of MPC and DPC: Case 1: Overwrite Base/Extended Service - If you have redefined an existing service, an additional section Service Extension will appear in this wizard. And make that property as etag, So if simple entity is there which were created using structure then just put the property name of timestamp as below image —. Till SEGW inherently provides that feature, here is how you can do it using code. Inside DEFINE method you are calling super->define ( ) for original service to add it annotation, later in the code you have inserted. Navigation-2 – HeadItemT. DateTime and by making a change to our local annotation file, we will now see it appear within the smart filter bar of our Fiori Elements application: Once complete, we. I want to define methods in Class which I am planning to use in standard methods of the class. MPC_EXT class in method DEFINE). OData MPC_EXT-DEFINE Code Collection; Mary Roopini A on SEGW – OData MPC_EXT-DEFINE Code Collection; Soko on How to. PUBLIC SECTION. 3. Run transaction SOAMANAGER and under ‘Service Administration’ tab click on ‘Web Service Configuration’. To access i18n properties, we need to load them in SAP-UI5 application. Now, For example, If You have defined 3 Properties in your entity type. For example the MPC_EXT class in this class already contains a redefinition of the DEFINE method. publish-Annotation" for the generation of the oData-Service and in this case there is no mpc_ext class available in the Service . 9. The method can look like this example: METHOD define. Go to Runtime Artifacts node, open the ZCL_ZGW_PRACTICE006_ MPC_EXT class in ABAP Workbench (Right-Click: Go to ABAP Workbench) & click on the Types tab. In addition, for the amount properties Precision and Scale are set according to the. data provider class is base class for data provider extension class. Now we need to redefine DEFINE Method in MPC_EXT class as below. super- > define ( ). Alternatively, select the project, and click , or from Project in the menu, click Generate. If your value help contains a fixed number of values, a dropdown list will be rendered. Remember that at this stage your fully functioning OData service is a result of purely declarative definitions. I tested CREATE_STREAM and works great, i've got the uploaded CSV file and inserted data into my custom table. With RDS, the SADL framework automatically implements the methods that are necessary for retrieving modifying data with OData in the data provider class (DPC). Naveen on How to upload Excel to SAP(using ABAP) Upamanyu Sarmah on S4 HANA Output Management – Introduction, Master Form Layout Edit and Setup; Pankaj on SAPScript symbols and. Basically this is a mapping between business logic types and entity that will be shown for the outside world. There the author used the UPDATE_STREAM method to UPLOAD the file to the SAP Back-end system. e. Voila! We are done. Another option to create the structure is to create one in MPC_EXT class i. During CDS activation OData service will be generated in the background. INCLUDE TYPE workorder_structure. Basic Object Page. Head entity definition in MPC *HeRefine the List Report with Annotations. In webide you can choose context menu New->Extension. Annotation @Consumption. storing XSTRING in SAP. Click on the project and select “Generate Runtime”. In terms of annotation. Example,*AE*,*AG41-1S*. publish-Annotation" for the generation of the oData-Service and in this case there is no mpc_ext class available in the Service . Click “Get Services”. Controller should appear in project under ext. cannot be changed after entry. Step 1: Create a basic OData service with an entity as mentioned above. Now we can see description showing in smartfilter. The selected implementation class opens in the Class Builder. Using the system query options as parameter,. super -> define ( ). 0, select the OData Service created ( YLAUFFER_TEST_MAIF_SRV 0001) and flag Active. You would have to work out yourself what parameters to supply, as it would vary based on what type. If the class open in ‘Display’ mode than convert it to ‘Change’ mode. g. Import the designed metadata file using File Import functionality. Tagged With: Tagged With: odata, sap basis. And, there will be an entity set SD_HEADER_SET. These are the techniques I would like to share: code based implementation. DATA(lo_entity_type) = model->get_entity_type( cl_eam_malfunction_mpc=>gc_c_maintordercomponenttptype ). You will then see Device Types tab. Update the data model definition using the MPC_EXT generated classClick “Add Service”. I am trying to implement SAP Fiori apps myTimesheet V2 and approve Timesheet V2 on an SAP ECC Ehp6 Backend. Code to Process Action. Now open DPC_EXT class. 50, SP- 0011. Following blogs can be referred for same: To create similar OData Service: Create OData Service in SAP Fiori Server. Annotations can be added in the DEFINE method of the Model Provider Extension class MPC_EXT:. Goto you MPC_EXT class. Why OData is used in SAP? OData is used to specify the best practices necessary to create and use RESTful APIs. A query provides read-only access to the database and it is. Recommended reading. Assign Model to Service . Redefine the DEFINE method from ZCL_Z_NOTIF_MPC_EXT to connect the 2 new entitysets as a search help in the Fiori UI by putting this coding: METHOD define. It was working perfectly fine. The app is working, create and update are working individually as well (I redefined the MPC_EXT define method to make the entity as sap:creatable="true" & sap:updatable="true". Introduction. How to you treat in UI5 the return of insert data table?You redefined only CREATE_STREAM (DPC_EXT) and DEFINE(MPC_EXT) methods. public section. Code detail :- class ZCL_ZMEDIA_MPC_EXT definition public inheriting from ZCL_ZMEDIA_MPC create public . if i redefine entity set read list method also it is not working. Usage in SAP S4 Output Management. Creating OData Mobile Data Object handler class. Naveen on How to upload Excel to SAP(using ABAP) Upamanyu Sarmah on S4 HANA Output Management – Introduction, Master Form Layout Edit and Setup; Pankaj on SAPScript symbols and formatting options; Mary Roopini A on SEGW – OData MPC_EXT-DEFINE Code Collection; Mary Roopini A on SEGW – OData MPC_EXT. I could use an implicit enhancement to add custom code to this. Naveen on How to upload Excel to SAP (using ABAP) Upamanyu Sarmah on S4 HANA Output Management – Introduction, Master Form Layout Edit and Setup. The "Einzelrollen" element is supposed to be a child of the "Rollen" element, as you can see when looking at the hierarchy-level / nodeid / parentNodeId. I tried to redefine the method DEFINE in the MPC_EXT class after which i dont see my entityset in my gateway client. Hi All, I am trying to model service to standard component for a datetime field where I can pass the range which must consider the select options in ABAP. DPC& DPC_EXT; MPC & MPC_EXT; The mentioned above are four classes generated by SAP. Here i am redefining DPC_EXT class methods to write my own logic. String with a length. Table. This scenario is suitable when the data is modelled through. ZCL_ZTEST_ODATA_MPC - Model Provider Class ZCL_ZTEST_ODATA_DPC - Data Provider Class In addition to it, the system also generates two more classes to perform any extensions to the above classes. Add following lines of code in method DEFINE of the MPC_EXT class. Model Provider Extension Class (suffix _MPC_EXT): This is the implementation class that inheritsWe are making use of importing parameter iv_slug to get some of the information. Set OData Version 2. Writing this as i searched several thread could not. 50, SP- 0011. This scenario is suitable when the data is modelled through the entities in SEGW. Specify template id and name, which will then appear in Custom tab. Now it’s time to add some simple business logic. IF lo_entity_type IS BOUND. The content of Define() method depends on the OData artifacts which are created for a model in SEGW (such as entity types, complex types, and more). The Wizard Step 1 of 2:. To prevent that the get_entityset method is getting called you have to fill your techclause e. Select Overwrite Base/Extended Service, to overwrite the. Annotation display-format will give you date picker in the field. We use the BOPF consumer api in the odata service. Below is the architecture of ABAP RESTful Application Programming Model to develop Odata services. U can check the above link how to implement Create Deep entity method. BCALV_DND_01 – Drag ALV Row to Tree Folder. This flag propagates information about conversion exits, currency and unit fields from ABAP Dictionary into metadata. I tried case statement in cds view to check null value but it's not working. 4. Go to STMS transaction in target system. Here are the steps to define and use a function import in SAP OData: Define the Function Import: In SAP Gateway Service Builder. In general, there are three types of query options in OData: system query options (define the amount and order of data returned, eg. Jan 28, 2015 at 09:01 AM. Here we will post data based on odata request , here we will explore more on Runtime Artifacts , The main two class are MDP( Model Provider class) and DPC ( Data provider Class). Entity Type 2 – ord_hdr. In this blog post i want to show how to connect Microsoft Power BI to SAP data using OData services. SAP Editable ALV Grid Sample Code. Create Deep Entity. methods DEFINE: redefinition . Problems after editing DPC_EXT and MPC_EXT. Your OData service will define an entity type, SD_HEADER for example. The generated definition for the OData service is contained in this class: ZCL_ZODATA_SERVICE_MPC, however, to implement the desired logic, the ZCL_ZODATA_SERVICE_MPC_EXT class will be extended with the additional code.