The following JScript example shows how to load an existing document with a simple mapping, access its components, set input- and output-instance file names and execute the mapping.
/* This sample file performs the following operations: Load existing MapForce mapping document. Find source and target component. Set input and output instance filenames. Execute the transformation. Works with Windows scripting host. */ // ---- general helpers ------------------------------ function Exit( message ) { WScript.Echo( message ); WScript.Quit(-1); } function ERROR( message, err ) { if( err != null ) Exit( "ERROR: (" + (err.number & 0xffff) + ") " + err.description + " - " + message ); else Exit( "ERROR: " + message ); } // ---- MapForce constants ----------------------- var eComponentUsageKind_Unknown = 0; var eComponentUsageKind_Instance = 1; var eComponentUsageKind_Input = 2; var eComponentUsageKind_Output = 3; // ---- MapForce helpers ----------------------- // Searches in the specified mapping for a component by name and returns it. // If not found, throws an error. function FindComponent( mapping, component_name ) { var components = mapping.Components; for( var i = 0 ; i < components.Count ; ++i ) { var component = components.Item( i + 1 ); if( component.Name == component_name ) return component; } throw new Error( "Cannot find component with name " + component_name ); } // Browses components in a mapping and returns the first one found acting as // source component (i.e. having connections on its right side). function GetFirstSourceComponent( mapping ) { var components = mapping.Components; for( var i = 0 ; i < components.Count ; ++i ) { var component = components.Item( i + 1 ); if( component.UsageKind == eComponentUsageKind_Instance && component.HasOutgoingConnections ) { return component; } } throw new Error( "Cannot find a source component" ); } // Browses components in a mapping and returns the first one found acting as // target component (i.e. having connections on its left side). function GetFirstTargetComponent( mapping ) { var components = mapping.Components; for( var i = 0 ; i < components.Count ; ++i ) { var component = components.Item( i + 1 ); if( component.UsageKind == eComponentUsageKind_Instance && component.HasIncomingConnections ) { return component; } } throw new Error( "Cannot find a target component" ); } function IndentTextLines( s ) { return "\t" + s.replace( /\/g, "\\t" ); } function GetAppoutputLineFullText( oAppoutputLine ) { var s = oAppoutputLine.GetLineText(); var oAppoutputChildLines = oAppoutputLine.ChildLines; var i; for( i = 0 ; i < oAppoutputChildLines.Count ; ++i ) { oAppoutputChildLine = oAppoutputChildLines.Item( i + 1 ); sChilds = GetAppoutputLineFullText( oAppoutputChildLine ); s += "\" + IndentTextLines( sChilds ); } return s; } // Create a nicely formatted string from AppOutputLines function GetResultMessagesString( oAppoutputLines ) { var s1 = "Transformation result messages:\"; var oAppoutputLine; var i; for( i = 0 ; i < oAppoutputLines.Count ; ++i ) { oAppoutputLine = oAppoutputLines.Item( i + 1 ); s1 += GetAppoutputLineFullText( oAppoutputLine ); s1 += "\"; } return s1; } // ---- MAIN ------------------------------------- var wshShell; var fso; var mapforce; // create the Shell and FileSystemObject of the windows scripting system try { wshShell = WScript.CreateObject( "WScript.Shell" ); fso = WScript.CreateObject( "Scripting.FileSystemObject" ); } catch( err ) { ERROR( "Can't create windows scripting objects", err ); } // open MapForce or access currently running instance try { mapforce = WScript.GetObject( "", "MapForce.Application" ); } catch( err ) { ERROR( "Can't access or create MapForce.Application", err ); } try { // Make MapForce UI visible. This is an API requirement for output generation. mapforce.Visible = true; // open an existing mapping. // **** adjust the examples path to your needs ! ************** var sMapForceExamplesPath = fso.BuildPath( wshShell.SpecialFolders( "MyDocuments" ), "Altova\\MapForce2023\\MapForceExamples" ); var sDocFilename = fso.BuildPath( sMapForceExamplesPath, "PersonList.mfd" ); var doc = mapforce.OpenDocument( sDocFilename ); // Find existing components by name in the main mapping. // Note, the names of components may not be unique as a schema component's name // is derived from its schema file name. var source_component = FindComponent( doc.MainMapping, "Employees" ); var target_component = FindComponent( doc.MainMapping, "PersonList" ); // If you do not know the names of the components for some reason, you could // use the following functions instead of FindComponent. //var source_component = GetFirstSourceComponent( doc.MainMapping ); //var target_component = GetFirstTargetComponent( doc.MainMapping ); // specify the desired input and output files. source_component.InputInstanceFile = fso.BuildPath( sMapForceExamplesPath, "Employees.xml" ); target_component.OutputInstanceFile = fso.BuildPath( sMapForceExamplesPath, "test_transformation_results.xml" ); // Perform the transformation. // You can use doc.GenerateOutput() if you do not need result messages. // If you have a mapping with more than one target component and you want // to execute the transformation only for one specific target component, // call target_component.GenerateOutput() instead. var result_messages = doc.GenerateOutputEx(); var summary_info = "Transformation performed from " + source_component.InputInstanceFile + "\" + "to " + target_component.OutputInstanceFile + "\" + GetResultMessagesString( result_messages ); WScript.Echo( summary_info ); } catch( err ) { ERROR( "Failure", err ); } |