sdaiPutAttrBN
Table 1 – Required value buffer depending on valueType (on the example of sdaiPutAttrBN but valid for all put-functions)
valueType C/C++ C#
sdaiINTEGER int_t val = 123; int_t val = 123;
sdaiPutAttrBN (inst, "attrName", sdaiINTEGER, &val); ifcengine.sdaiPutAttrBN (inst, "attrName", ifcengine.sdaiINTEGER, ref val);
sdaiREAL or sdaiNUMBER double val = 123.456; double val = 123.456;
sdaiPutAttrBN (inst, "attrName", sdaiREAL, &val); ifcengine.sdaiPutAttrBN (inst, "attrName", ifcengine.sdaiREAL, ref val);
sdaiBOOLEAN bool val = true; bool val = true;
sdaiPutAttrBN (inst, "attrName", sdaiBOOLEAN, &val); ifcengine.sdaiPutAttrBN (inst, "attrName", ifcengine.sdaiBOOLEAN, ref val);
sdaiLOGICAL const TCHAR* val = "U"; string val = "U";
sdaiPutAttrBN (inst, "attrName", sdaiLOGICAL, val); ifcengine.sdaiPutAttrBN (inst, "attrName", ifcengine.sdaiLOGICAL, val);
sdaiENUM const TCHAR* val = "NOTDEFINED"; string val = "NOTDEFINED";
sdaiPutAttrBN (inst, "attrName", sdaiENUM, val); ifcengine.sdaiPutAttrBN (inst, "attrName", ifcengine.sdaiENUM, val);
sdaiBINARY const TCHAR* val = "0123456ABC"; string val = "0123456ABC";
sdaiPutAttrBN (inst, "attrName", sdaiBINARY, val); ifcengine.sdaiPutAttrBN (inst, "attrName", ifcengine.sdaiBINARY, val);
sdaiSTRING const char* val = "My Simple String"; string val = "My Simple String";
sdaiPutAttrBN (inst, "attrName", sdaiSTRING, val); ifcengine.sdaiPutAttrBN (inst, "attrName", ifcengine.sdaiSTRING, val);
sdaiUNICODE const wchar_t* val = L"Any Unicode String"; string val = "Any Unicode String";
sdaiPutAttrBN (inst, "attrName", sdaiUNICODE, val); ifcengine.sdaiPutAttrBN (inst, "attrName", ifcengine.sdaiUNICODE, val);
sdaiEXPRESSSTRING const char* val = "EXPRESS format, i.e. \\X2\\00FC\\X0\\"; string val = "EXPRESS format, i.e. \\X2\\00FC\\X0\\";
sdaiPutAttrBN (inst, "attrName", sdaiEXPRESSSTRING, val); ifcengine.sdaiPutAttrBN (inst, "attrName", ifcengine.sdaiEXPRESSSTRING, val);
sdaiINSTANCE SdaiInstance val = sdaiCreateInstanceBN (model, "IFCSITE"); int_t val = ifcengine.sdaiCreateInstanceBN (model, "IFCSITE");
sdaiPutAttrBN (inst, "attrName", sdaiINSTANCE, val); ifcengine.sdaiPutAttrBN (inst, "attrName", ifcengine.sdaiINSTANCE, val);
sdaiAGGR SdaiAggr val = sdaiCreateAggr (inst, 0); int_t val = sdaiCreateAggr (inst, 0);
sdaiAppend (val, sdaiINSTANCE, inst); ifcengine.sdaiAppend (val, ifcengine.sdaiINSTANCE, inst);
sdaiPutAttrBN (inst, "attrName", sdaiAGGR, val); ifcengine.sdaiPutAttrBN (inst, "attrName", ifcengine.sdaiAGGR, val);
sdaiADB int_t integerValue = 123; int_t integerValue = 123;
SdaiADB val = sdaiCreateADB (sdaiINTEGER, &integerValue); int_t val = ifcengine.sdaiCreateADB (ifcengine.sdaiINTEGER, ref integerValue);
sdaiPutADBTypePath (val, 1, "IFCINTEGER"); ifcengine.sdaiPutADBTypePath (val, 1, "IFCINTEGER");
sdaiPutAttrBN (inst, "attrName", sdaiADB, val); ifcengine.sdaiPutAttrBN (inst, "attrName", ifcengine.sdaiADB, val);
sdaiDeleteADB (val); ifcengine.sdaiDeleteADB (val);
TCHAR is “char” or “wchar_t” depending on setStringUnicode.
(Non-standard behavior) sdaiLOGICAL behaves differently from ISO 10303-24-2001: it expects char* while standard declares int_t
(Non-standard extension) sdiADB in C++ has an option to work without sdaiCreateEmptyADB and sdaiDeleteADB as shown in the table
Table 2 - valueType can be requested depending on actual model data.
valueType Works for following values in the model
integer real .T. or .F. .U. other enum binary string instance list $ (empty)
sdaiINTEGER Yes . . . . . . . . .
sdaiREAL . Yes . . . . . . . .
sdaiNUMBER . Yes . . . . . . . .
sdaiBOOLEAN . . Yes . . . . . . .
sdaiLOGICAL . . Yes Yes . . . . . .
sdaiENUM . . Yes Yes Yes . . . . .
sdaiBINARY . . . . . Yes . . . .
sdaiSTRING . . . . . . Yes . . .
sdaiUNICODE . . . . . . Yes . . .
sdaiEXPRESSSTRING . . . . . . Yes . . .
sdaiINSTANCE . . . . . . . Yes . .
sdaiAGGR . . . . . . . . Yes .
sdaiADB Yes Yes Yes Yes Yes Yes Yes Yes Yes .
Technically sdaiPutAttrBN will transform into the following call
sdaiPutAttr(
instance,
sdaiGetAttrDefinition(
sdaiGetInstanceType(
instance
),
attributeName
),
valueType,
value
);
Syntax
public const string ifcenginedll = @"ifcengine.dll"; [DllImport(IFCEngineDLL, EntryPoint = "sdaiPutAttrBN")] public static extern void sdaiPutAttrBN(int_t instance, string attributeName, int_t valueType, ref bool value); [DllImport(IFCEngineDLL, EntryPoint = "sdaiPutAttrBN")] public static extern void sdaiPutAttrBN(int_t instance, string attributeName, int_t valueType, ref int_t value); [DllImport(IFCEngineDLL, EntryPoint = "sdaiPutAttrBN")] public static extern void sdaiPutAttrBN(int_t instance, string attributeName, int_t valueType, int_t value); [DllImport(IFCEngineDLL, EntryPoint = "sdaiPutAttrBN")] public static extern void sdaiPutAttrBN(int_t instance, string attributeName, int_t valueType, ref double value); [DllImport(IFCEngineDLL, EntryPoint = "sdaiPutAttrBN")] public static extern void sdaiPutAttrBN(int_t instance, string attributeName, int_t valueType, ref IntPtr value); [DllImport(IFCEngineDLL, EntryPoint = "sdaiPutAttrBN")] public static extern void sdaiPutAttrBN(int_t instance, string attributeName, int_t valueType, byte[] value); [DllImport(IFCEngineDLL, EntryPoint = "sdaiPutAttrBN")] public static extern void sdaiPutAttrBN(int_t instance, string attributeName, int_t valueType, string value); [DllImport(IFCEngineDLL, EntryPoint = "sdaiPutAttrBN")] public static extern void sdaiPutAttrBN(int_t instance, byte[] attributeName, int_t valueType, ref bool value); [DllImport(IFCEngineDLL, EntryPoint = "sdaiPutAttrBN")] public static extern void sdaiPutAttrBN(int_t instance, byte[] attributeName, int_t valueType, ref int_t value); [DllImport(IFCEngineDLL, EntryPoint = "sdaiPutAttrBN")] public static extern void sdaiPutAttrBN(int_t instance, byte[] attributeName, int_t valueType, int_t value); [DllImport(IFCEngineDLL, EntryPoint = "sdaiPutAttrBN")] public static extern void sdaiPutAttrBN(int_t instance, byte[] attributeName, int_t valueType, ref double value); [DllImport(IFCEngineDLL, EntryPoint = "sdaiPutAttrBN")] public static extern void sdaiPutAttrBN(int_t instance, byte[] attributeName, int_t valueType, ref IntPtr value); [DllImport(IFCEngineDLL, EntryPoint = "sdaiPutAttrBN")] public static extern void sdaiPutAttrBN(int_t instance, byte[] attributeName, int_t valueType, byte[] value); [DllImport(IFCEngineDLL, EntryPoint = "sdaiPutAttrBN")] public static extern void sdaiPutAttrBN(int_t instance, byte[] attributeName, int_t valueType, string value);
Property instance
Size: 32 bit / 4 byte (value)Property attributeName
Size: 32 bit / 4 byte (reference)Property valueType
Size: 32 bit / 4 byte (value)Property value
Size: 32 bit / 4 byte (reference)
Example (based on pure API calls)
Here you can find code snippits that show how the API call sdaiPutAttrBN can be used.
using RDF; // include at least engine.cs within your solution // // Created result when stored as IFC: // #31313 = IFCPOSTALADDRESS($, $, $, $, ('RDF Ltd.', 'Main Office'), '32', 'Bankya', 'Sofia', '1320', 'Bulgaria'); // Int64 ifcPostalAddressInstance = IfcEngine.x64.sdaiCreateInstanceBN(model, System.Text.Encoding.UTF8.GetBytes("IFCPOSTALADDRESS")); Int64 addressLines = IfcEngine.x64.sdaiCreateAggrBN(ifcPostalAddressInstance, System.Text.Encoding.UTF8.GetBytes("AddressLines")); IfcEngine.x64.sdaiAppend(addressLines, IfcEngine.x64.sdaiSTRING, System.Text.Encoding.UTF8.GetBytes("RDF Ltd.")); IfcEngine.x64.sdaiAppend(addressLines, IfcEngine.x64.sdaiSTRING, System.Text.Encoding.UTF8.GetBytes("Main Office")); IfcEngine.x64.sdaiPutAttrBN(ifcPostalAddressInstance, System.Text.Encoding.UTF8.GetBytes("PostalBox"), IfcEngine.x64.sdaiSTRING, System.Text.Encoding.UTF8.GetBytes("32")); IfcEngine.x64.sdaiPutAttrBN(ifcPostalAddressInstance, System.Text.Encoding.UTF8.GetBytes("Town"), IfcEngine.x64.sdaiSTRING, System.Text.Encoding.UTF8.GetBytes("Bankya")); IfcEngine.x64.sdaiPutAttrBN(ifcPostalAddressInstance, System.Text.Encoding.UTF8.GetBytes("Region"), IfcEngine.x64.sdaiSTRING, System.Text.Encoding.UTF8.GetBytes("Sofia")); // It is allowed to mix sdaiUNICODE and sdaiSTRING IfcEngine.x64.sdaiPutAttrBN(ifcPostalAddressInstance, System.Text.Encoding.UTF8.GetBytes("PostalCode"), IfcEngine.x64.sdaiUNICODE, System.Text.Encoding.Unicode.GetBytes("1320")); // as long as each call is consitent in itself. IfcEngine.x64.sdaiPutAttrBN(ifcPostalAddressInstance, System.Text.Encoding.UTF8.GetBytes("Country"), IfcEngine.x64.sdaiSTRING, System.Text.Encoding.UTF8.GetBytes("Bulgaria"));