mirror of
https://github.com/danieleteti/delphimvcframework.git
synced 2024-11-15 07:45:54 +01:00
3.2.0-boron-RC4
This commit is contained in:
parent
4a78322aef
commit
c36cd13988
@ -77,6 +77,7 @@ Congratulations to Daniele Teti and all the staff for the excellent work!" -- Ma
|
||||
> WARNING! Considering the huge amount of features added in 3.1.1-beryllium during its RC phase, the dmvcframework-3.1.1-beryllium has been renamed to dmvcframework-3.2.0-boron
|
||||
|
||||
- New! Added Nullable support in MVCActiveRecord! Check *activerecord_showcase* sample.
|
||||
- New! Complete support for nullable types in the default serializer.
|
||||
- New! Added Swagger support (thanks to [João Antônio Duarte](https://github.com/joaoduarte19) and [Geoffrey Smith](https://github.com/geoffsmith82))
|
||||
- New! Added SQLGenerator and RQL compiler for PostgreSQL, SQLite and MSSQLServer (in addition to MySQL, MariaDB, Firebird and Interbase)
|
||||
- New! Added support for interfaces serialization - now it is possible to serialize Spring4D collections (thanks to [João Antônio Duarte](https://github.com/joaoduarte19))
|
||||
@ -139,6 +140,7 @@ Render(lPerson, False,
|
||||
- New! `TMVCAnalyticsMiddleware` to do automatic analytics on the API (generates a CSV file). Based on an idea by Nirav Kaku (https://www.facebook.com/nirav.kaku). Check the sample in `\samples\middleware_analytics\`
|
||||
- New! `TMVCActiveRecord.DeleteAll` deletes all the records from a table
|
||||
- New! `TMVCActiveRecord.DeleteRQL` deletes records using an `RQL` expression as `where` clause.
|
||||
- New! `TMVCActiveRecord.Store` which automatically executes Insert or Update considering primary key value.
|
||||
- New! Microsoft SQLServer Support in `MVCActiveRecord` and RQL (*thanks to one of the biggest Delphi based company in Italy which heavily uses DMVCFramework* and *[DMSContainer](http://www.bittimeprofessionals.it/prodotti/dmscontainer)*)
|
||||
- New! SQLite support in `MVCActiveRecord` and RQL, so that `MVCActiveRecord` can be used also for Delphi mobile projects!
|
||||
- Default JSON Serializer can verbatim pass properties with type `JsonDataObjects.TJSONObject` without using `string` as carrier of JSON
|
||||
|
@ -174,9 +174,9 @@ var
|
||||
begin
|
||||
// You can write your own entity which already load relations
|
||||
// The following is the manual approach
|
||||
lContact := TContact.GetByPK<TContact>(id);
|
||||
lContact := TMVCActiveRecord.GetByPK<TContact>(id);
|
||||
try
|
||||
lPhones := TPhone.Where<TPhone>('id_person = ?', [id]);
|
||||
lPhones := TMVCActiveRecord.Where<TPhone>('id_person = ?', [id]);
|
||||
try
|
||||
lSer := TMVCJsonDataObjectsSerializer.Create;
|
||||
try
|
||||
|
@ -8,7 +8,6 @@ uses
|
||||
FireDAC.Phys.MySQL,
|
||||
FireDAC.Phys.SQLite,
|
||||
System.SysUtils,
|
||||
MVCFramework.Logger,
|
||||
MVCFramework.Commons,
|
||||
MVCFramework.REPLCommandsHandlerU,
|
||||
Web.ReqMulti,
|
||||
|
@ -1,14 +1,14 @@
|
||||
<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||
<PropertyGroup>
|
||||
<ProjectGuid>{AA03EFF9-BE4C-4D2B-A76F-61F472553AE2}</ProjectGuid>
|
||||
<ProjectVersion>18.7</ProjectVersion>
|
||||
<FrameworkType>VCL</FrameworkType>
|
||||
<ProjectGuid>{577870BB-C138-49DA-BB88-AF1737526F46}</ProjectGuid>
|
||||
<MainSource>activerecord_crud.dpr</MainSource>
|
||||
<Base>True</Base>
|
||||
<Config Condition="'$(Config)'==''">Debug</Config>
|
||||
<Platform Condition="'$(Platform)'==''">Win64</Platform>
|
||||
<TargetedPlatforms>3</TargetedPlatforms>
|
||||
<TargetedPlatforms>36993</TargetedPlatforms>
|
||||
<AppType>Console</AppType>
|
||||
<FrameworkType>None</FrameworkType>
|
||||
<ProjectVersion>18.8</ProjectVersion>
|
||||
<Platform Condition="'$(Platform)'==''">Win32</Platform>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Config)'=='Base' or '$(Base)'!=''">
|
||||
<Base>true</Base>
|
||||
@ -18,8 +18,23 @@
|
||||
<CfgParent>Base</CfgParent>
|
||||
<Base>true</Base>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="('$(Platform)'=='Linux64' and '$(Base)'=='true') or '$(Base_Linux64)'!=''">
|
||||
<Base_Linux64>true</Base_Linux64>
|
||||
<PropertyGroup Condition="('$(Platform)'=='Android64' and '$(Base)'=='true') or '$(Base_Android64)'!=''">
|
||||
<Base_Android64>true</Base_Android64>
|
||||
<CfgParent>Base</CfgParent>
|
||||
<Base>true</Base>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="('$(Platform)'=='iOSDevice32' and '$(Base)'=='true') or '$(Base_iOSDevice32)'!=''">
|
||||
<Base_iOSDevice32>true</Base_iOSDevice32>
|
||||
<CfgParent>Base</CfgParent>
|
||||
<Base>true</Base>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="('$(Platform)'=='iOSDevice64' and '$(Base)'=='true') or '$(Base_iOSDevice64)'!=''">
|
||||
<Base_iOSDevice64>true</Base_iOSDevice64>
|
||||
<CfgParent>Base</CfgParent>
|
||||
<Base>true</Base>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="('$(Platform)'=='iOSSimulator' and '$(Base)'=='true') or '$(Base_iOSSimulator)'!=''">
|
||||
<Base_iOSSimulator>true</Base_iOSSimulator>
|
||||
<CfgParent>Base</CfgParent>
|
||||
<Base>true</Base>
|
||||
</PropertyGroup>
|
||||
@ -33,99 +48,142 @@
|
||||
<CfgParent>Base</CfgParent>
|
||||
<Base>true</Base>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Config)'=='Debug' or '$(Cfg_1)'!=''">
|
||||
<PropertyGroup Condition="'$(Config)'=='Release' or '$(Cfg_1)'!=''">
|
||||
<Cfg_1>true</Cfg_1>
|
||||
<CfgParent>Base</CfgParent>
|
||||
<Base>true</Base>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="('$(Platform)'=='Win32' and '$(Cfg_1)'=='true') or '$(Cfg_1_Win32)'!=''">
|
||||
<Cfg_1_Win32>true</Cfg_1_Win32>
|
||||
<CfgParent>Cfg_1</CfgParent>
|
||||
<Cfg_1>true</Cfg_1>
|
||||
<Base>true</Base>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="('$(Platform)'=='Win64' and '$(Cfg_1)'=='true') or '$(Cfg_1_Win64)'!=''">
|
||||
<Cfg_1_Win64>true</Cfg_1_Win64>
|
||||
<CfgParent>Cfg_1</CfgParent>
|
||||
<Cfg_1>true</Cfg_1>
|
||||
<Base>true</Base>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Config)'=='Release' or '$(Cfg_2)'!=''">
|
||||
<PropertyGroup Condition="'$(Config)'=='Debug' or '$(Cfg_2)'!=''">
|
||||
<Cfg_2>true</Cfg_2>
|
||||
<CfgParent>Base</CfgParent>
|
||||
<Base>true</Base>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="('$(Platform)'=='Android64' and '$(Cfg_2)'=='true') or '$(Cfg_2_Android64)'!=''">
|
||||
<Cfg_2_Android64>true</Cfg_2_Android64>
|
||||
<CfgParent>Cfg_2</CfgParent>
|
||||
<Cfg_2>true</Cfg_2>
|
||||
<Base>true</Base>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="('$(Platform)'=='OSX64' and '$(Cfg_2)'=='true') or '$(Cfg_2_OSX64)'!=''">
|
||||
<Cfg_2_OSX64>true</Cfg_2_OSX64>
|
||||
<CfgParent>Cfg_2</CfgParent>
|
||||
<Cfg_2>true</Cfg_2>
|
||||
<Base>true</Base>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Base)'!=''">
|
||||
<DCC_DcuOutput>.\$(Platform)\$(Config)</DCC_DcuOutput>
|
||||
<DCC_ExeOutput>.\$(Platform)\$(Config)</DCC_ExeOutput>
|
||||
<DCC_E>false</DCC_E>
|
||||
<DCC_N>false</DCC_N>
|
||||
<DCC_S>false</DCC_S>
|
||||
<DCC_F>false</DCC_F>
|
||||
<DCC_K>false</DCC_K>
|
||||
<DCC_UsePackage>RESTComponents;emsclientfiredac;DataSnapFireDAC;FireDACIBDriver;emsclient;FireDACCommon;RESTBackendComponents;soapserver;CloudService;FireDACCommonDriver;inet;FireDAC;FireDACSqliteDriver;soaprtl;soapmidas;$(DCC_UsePackage)</DCC_UsePackage>
|
||||
<DCC_Namespace>System;Xml;Data;Datasnap;Web;Soap;Vcl;Vcl.Imaging;Vcl.Touch;Vcl.Samples;Vcl.Shell;$(DCC_Namespace)</DCC_Namespace>
|
||||
<UsingDelphiRTL>true</UsingDelphiRTL>
|
||||
<DCC_N>false</DCC_N>
|
||||
<DCC_S>false</DCC_S>
|
||||
<DCC_ImageBase>00400000</DCC_ImageBase>
|
||||
<SanitizedProjectName>activerecord_crud</SanitizedProjectName>
|
||||
<VerInfo_Locale>1040</VerInfo_Locale>
|
||||
<VerInfo_Keys>CompanyName=;FileDescription=;FileVersion=1.0.0.0;InternalName=;LegalCopyright=;LegalTrademarks=;OriginalFilename=;ProductName=;ProductVersion=1.0.0.0;Comments=;CFBundleName=</VerInfo_Keys>
|
||||
<DCC_Namespace>System;Xml;Data;Datasnap;Web;Soap;$(DCC_Namespace)</DCC_Namespace>
|
||||
<Icon_MainIcon>$(BDS)\bin\delphi_PROJECTICON.ico</Icon_MainIcon>
|
||||
<Icns_MainIcns>$(BDS)\bin\delphi_PROJECTICNS.icns</Icns_MainIcns>
|
||||
<DCC_UnitSearchPath>$(DMVC);$(DCC_UnitSearchPath)</DCC_UnitSearchPath>
|
||||
<DCC_Framework>VCL;$(DCC_Framework)</DCC_Framework>
|
||||
<SanitizedProjectName>activerecord_crud</SanitizedProjectName>
|
||||
<DCC_CASE_LABEL_RANGE>error</DCC_CASE_LABEL_RANGE>
|
||||
<DCC_UNSUPPORTED_CONSTRUCT>error</DCC_UNSUPPORTED_CONSTRUCT>
|
||||
<VerInfo_Locale>1040</VerInfo_Locale>
|
||||
<VerInfo_Keys>CompanyName=;FileDescription=$(MSBuildProjectName);FileVersion=1.0.0.0;InternalName=;LegalCopyright=;LegalTrademarks=;OriginalFilename=;ProgramID=com.embarcadero.$(MSBuildProjectName);ProductName=$(MSBuildProjectName);ProductVersion=1.0.0.0;Comments=</VerInfo_Keys>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Base_Android)'!=''">
|
||||
<DCC_UsePackage>DBXSqliteDriver;DBXInterBaseDriver;tethering;bindcompfmx;fmx;FireDACDBXDriver;dbexpress;IndyCore;dsnap;DataSnapCommon;bindengine;DataSnapClient;IndyIPCommon;bindcompdbx;IndyIPServer;IndySystem;fmxFireDAC;DbxCommonDriver;xmlrtl;DataSnapNativeClient;FireDACDSDriver;rtl;DbxClientDriver;CustomIPTransport;bindcomp;IndyIPClient;dbxcds;dsnapxml;DataSnapProviderClient;dbrtl;IndyProtocols;$(DCC_UsePackage)</DCC_UsePackage>
|
||||
<EnabledSysJars>android-support-v4.dex.jar;cloud-messaging.dex.jar;fmx.dex.jar;google-analytics-v2.dex.jar;google-play-billing.dex.jar;google-play-licensing.dex.jar;google-play-services-ads-7.0.0.dex.jar;google-play-services-analytics-7.0.0.dex.jar;google-play-services-base-7.0.0.dex.jar;google-play-services-identity-7.0.0.dex.jar;google-play-services-maps-7.0.0.dex.jar;google-play-services-panorama-7.0.0.dex.jar;google-play-services-plus-7.0.0.dex.jar;google-play-services-wallet-7.0.0.dex.jar</EnabledSysJars>
|
||||
<VerInfo_Keys>package=com.embarcadero.$(MSBuildProjectName);label=$(MSBuildProjectName);versionCode=1;versionName=1.0.0;persistent=False;restoreAnyVersion=False;installLocation=auto;largeHeap=False;theme=TitleBar;hardwareAccelerated=true;apiKey=</VerInfo_Keys>
|
||||
<BT_BuildType>Debug</BT_BuildType>
|
||||
<Android_LauncherIcon36>$(BDS)\bin\Artwork\Android\FM_LauncherIcon_36x36.png</Android_LauncherIcon36>
|
||||
<Android_LauncherIcon48>$(BDS)\bin\Artwork\Android\FM_LauncherIcon_48x48.png</Android_LauncherIcon48>
|
||||
<Android_LauncherIcon72>$(BDS)\bin\Artwork\Android\FM_LauncherIcon_72x72.png</Android_LauncherIcon72>
|
||||
<Android_LauncherIcon96>$(BDS)\bin\Artwork\Android\FM_LauncherIcon_96x96.png</Android_LauncherIcon96>
|
||||
<Android_LauncherIcon144>$(BDS)\bin\Artwork\Android\FM_LauncherIcon_144x144.png</Android_LauncherIcon144>
|
||||
<Android_SplashImage426>$(BDS)\bin\Artwork\Android\FM_SplashImage_426x320.png</Android_SplashImage426>
|
||||
<Android_SplashImage470>$(BDS)\bin\Artwork\Android\FM_SplashImage_470x320.png</Android_SplashImage470>
|
||||
<Android_SplashImage640>$(BDS)\bin\Artwork\Android\FM_SplashImage_640x480.png</Android_SplashImage640>
|
||||
<Android_SplashImage960>$(BDS)\bin\Artwork\Android\FM_SplashImage_960x720.png</Android_SplashImage960>
|
||||
<AUP_ACCESS_COARSE_LOCATION>true</AUP_ACCESS_COARSE_LOCATION>
|
||||
<AUP_ACCESS_FINE_LOCATION>true</AUP_ACCESS_FINE_LOCATION>
|
||||
<AUP_CALL_PHONE>true</AUP_CALL_PHONE>
|
||||
<AUP_CAMERA>true</AUP_CAMERA>
|
||||
<AUP_INTERNET>true</AUP_INTERNET>
|
||||
<AUP_READ_CALENDAR>true</AUP_READ_CALENDAR>
|
||||
<AUP_READ_EXTERNAL_STORAGE>true</AUP_READ_EXTERNAL_STORAGE>
|
||||
<AUP_WRITE_CALENDAR>true</AUP_WRITE_CALENDAR>
|
||||
<AUP_WRITE_EXTERNAL_STORAGE>true</AUP_WRITE_EXTERNAL_STORAGE>
|
||||
<AUP_READ_PHONE_STATE>true</AUP_READ_PHONE_STATE>
|
||||
<Android_NotificationIcon24>$(BDS)\bin\Artwork\Android\FM_NotificationIcon_24x24.png</Android_NotificationIcon24>
|
||||
<Android_NotificationIcon36>$(BDS)\bin\Artwork\Android\FM_NotificationIcon_36x36.png</Android_NotificationIcon36>
|
||||
<Android_NotificationIcon48>$(BDS)\bin\Artwork\Android\FM_NotificationIcon_48x48.png</Android_NotificationIcon48>
|
||||
<Android_NotificationIcon72>$(BDS)\bin\Artwork\Android\FM_NotificationIcon_72x72.png</Android_NotificationIcon72>
|
||||
<Android_NotificationIcon96>$(BDS)\bin\Artwork\Android\FM_NotificationIcon_96x96.png</Android_NotificationIcon96>
|
||||
<EnabledSysJars>android-support-v4.dex.jar;cloud-messaging.dex.jar;com-google-android-gms.play-services-ads-base.17.2.0.dex.jar;com-google-android-gms.play-services-ads-identifier.16.0.0.dex.jar;com-google-android-gms.play-services-ads-lite.17.2.0.dex.jar;com-google-android-gms.play-services-ads.17.2.0.dex.jar;com-google-android-gms.play-services-analytics-impl.16.0.8.dex.jar;com-google-android-gms.play-services-analytics.16.0.8.dex.jar;com-google-android-gms.play-services-base.16.0.1.dex.jar;com-google-android-gms.play-services-basement.16.2.0.dex.jar;com-google-android-gms.play-services-gass.17.2.0.dex.jar;com-google-android-gms.play-services-identity.16.0.0.dex.jar;com-google-android-gms.play-services-maps.16.1.0.dex.jar;com-google-android-gms.play-services-measurement-base.16.4.0.dex.jar;com-google-android-gms.play-services-measurement-sdk-api.16.4.0.dex.jar;com-google-android-gms.play-services-stats.16.0.1.dex.jar;com-google-android-gms.play-services-tagmanager-v4-impl.16.0.8.dex.jar;com-google-android-gms.play-services-tasks.16.0.1.dex.jar;com-google-android-gms.play-services-wallet.16.0.1.dex.jar;com-google-firebase.firebase-analytics.16.4.0.dex.jar;com-google-firebase.firebase-common.16.1.0.dex.jar;com-google-firebase.firebase-iid-interop.16.0.1.dex.jar;com-google-firebase.firebase-iid.17.1.1.dex.jar;com-google-firebase.firebase-measurement-connector.17.0.1.dex.jar;com-google-firebase.firebase-messaging.17.5.0.dex.jar;fmx.dex.jar;google-play-billing.dex.jar;google-play-licensing.dex.jar</EnabledSysJars>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Base_Linux64)'!=''">
|
||||
<DCC_UsePackage>FireDACADSDriver;rtcSDK;DatasnapConnectorsFreePascal;FireDACMSSQLDriver;PythonVCL_D;inetdb;emsedge;dbexpress;IndyCore;dsnap;DataSnapCommon;DataSnapConnectors;bindengine;FireDACOracleDriver;FireDACMySQLDriver;FireDACCommonODBC;DataSnapClient;rtcSDK_DBA;IndySystem;FireDACDb2Driver;FireDACInfxDriver;emshosting;FireDACPgDriver;FireDACASADriver;FireDACTDataDriver;DbxCommonDriver;DataSnapServer;xmlrtl;DataSnapNativeClient;rtl;DbxClientDriver;CustomIPTransport;bindcomp;dbxcds;FireDACODBCDriver;DataSnapIndy10ServerTransport;dsnapxml;dbrtl;IndyProtocols;FireDACMongoDBDriver;DataSnapServerMidas;$(DCC_UsePackage)</DCC_UsePackage>
|
||||
<PropertyGroup Condition="'$(Base_Android64)'!=''">
|
||||
<EnabledSysJars>android-support-v4.dex.jar;cloud-messaging.dex.jar;com-google-android-gms.play-services-ads-base.17.2.0.dex.jar;com-google-android-gms.play-services-ads-identifier.16.0.0.dex.jar;com-google-android-gms.play-services-ads-lite.17.2.0.dex.jar;com-google-android-gms.play-services-ads.17.2.0.dex.jar;com-google-android-gms.play-services-analytics-impl.16.0.8.dex.jar;com-google-android-gms.play-services-analytics.16.0.8.dex.jar;com-google-android-gms.play-services-base.16.0.1.dex.jar;com-google-android-gms.play-services-basement.16.2.0.dex.jar;com-google-android-gms.play-services-gass.17.2.0.dex.jar;com-google-android-gms.play-services-identity.16.0.0.dex.jar;com-google-android-gms.play-services-maps.16.1.0.dex.jar;com-google-android-gms.play-services-measurement-base.16.4.0.dex.jar;com-google-android-gms.play-services-measurement-sdk-api.16.4.0.dex.jar;com-google-android-gms.play-services-stats.16.0.1.dex.jar;com-google-android-gms.play-services-tagmanager-v4-impl.16.0.8.dex.jar;com-google-android-gms.play-services-tasks.16.0.1.dex.jar;com-google-android-gms.play-services-wallet.16.0.1.dex.jar;com-google-firebase.firebase-analytics.16.4.0.dex.jar;com-google-firebase.firebase-common.16.1.0.dex.jar;com-google-firebase.firebase-iid-interop.16.0.1.dex.jar;com-google-firebase.firebase-iid.17.1.1.dex.jar;com-google-firebase.firebase-measurement-connector.17.0.1.dex.jar;com-google-firebase.firebase-messaging.17.5.0.dex.jar;fmx.dex.jar;google-play-billing.dex.jar;google-play-licensing.dex.jar</EnabledSysJars>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Base_iOSDevice32)'!=''">
|
||||
<iPhone_AppIcon60>$(BDS)\bin\Artwork\iOS\iPhone\FM_ApplicationIcon_60x60.png</iPhone_AppIcon60>
|
||||
<iPhone_AppIcon120>$(BDS)\bin\Artwork\iOS\iPhone\FM_ApplicationIcon_120x120.png</iPhone_AppIcon120>
|
||||
<iPhone_Spotlight40>$(BDS)\bin\Artwork\iOS\iPhone\FM_SpotlightSearchIcon_40x40.png</iPhone_Spotlight40>
|
||||
<iPhone_Spotlight80>$(BDS)\bin\Artwork\iOS\iPhone\FM_SpotlightSearchIcon_80x80.png</iPhone_Spotlight80>
|
||||
<iPad_SpotLight40>$(BDS)\bin\Artwork\iOS\iPad\FM_SpotlightSearchIcon_40x40.png</iPad_SpotLight40>
|
||||
<iPad_SpotLight80>$(BDS)\bin\Artwork\iOS\iPad\FM_SpotlightSearchIcon_80x80.png</iPad_SpotLight80>
|
||||
<iPad_AppIcon76>$(BDS)\bin\Artwork\iOS\iPad\FM_ApplicationIcon_76x76.png</iPad_AppIcon76>
|
||||
<iPad_AppIcon152>$(BDS)\bin\Artwork\iOS\iPad\FM_ApplicationIcon_152x152.png</iPad_AppIcon152>
|
||||
<iPad_Launch768x1024>$(BDS)\bin\Artwork\iOS\iPad\FM_LaunchImagePortrait_768x1024.png</iPad_Launch768x1024>
|
||||
<iPad_Launch1024x768>$(BDS)\bin\Artwork\iOS\iPad\FM_LaunchImageLandscape_1024x768.png</iPad_Launch1024x768>
|
||||
<iPad_Launch1536x2048>$(BDS)\bin\Artwork\iOS\iPad\FM_LaunchImagePortrait_1536x2048.png</iPad_Launch1536x2048>
|
||||
<iPad_Launch2048x1536>$(BDS)\bin\Artwork\iOS\iPad\FM_LaunchImageLandscape_2048x1536.png</iPad_Launch2048x1536>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Base_iOSDevice64)'!=''">
|
||||
<iPhone_AppIcon60>$(BDS)\bin\Artwork\iOS\iPhone\FM_ApplicationIcon_60x60.png</iPhone_AppIcon60>
|
||||
<iPhone_AppIcon120>$(BDS)\bin\Artwork\iOS\iPhone\FM_ApplicationIcon_120x120.png</iPhone_AppIcon120>
|
||||
<iPhone_Spotlight40>$(BDS)\bin\Artwork\iOS\iPhone\FM_SpotlightSearchIcon_40x40.png</iPhone_Spotlight40>
|
||||
<iPhone_Spotlight80>$(BDS)\bin\Artwork\iOS\iPhone\FM_SpotlightSearchIcon_80x80.png</iPhone_Spotlight80>
|
||||
<iPad_SpotLight40>$(BDS)\bin\Artwork\iOS\iPad\FM_SpotlightSearchIcon_40x40.png</iPad_SpotLight40>
|
||||
<iPad_SpotLight80>$(BDS)\bin\Artwork\iOS\iPad\FM_SpotlightSearchIcon_80x80.png</iPad_SpotLight80>
|
||||
<iPad_AppIcon76>$(BDS)\bin\Artwork\iOS\iPad\FM_ApplicationIcon_76x76.png</iPad_AppIcon76>
|
||||
<iPad_AppIcon152>$(BDS)\bin\Artwork\iOS\iPad\FM_ApplicationIcon_152x152.png</iPad_AppIcon152>
|
||||
<iPad_Launch768x1024>$(BDS)\bin\Artwork\iOS\iPad\FM_LaunchImagePortrait_768x1024.png</iPad_Launch768x1024>
|
||||
<iPad_Launch1024x768>$(BDS)\bin\Artwork\iOS\iPad\FM_LaunchImageLandscape_1024x768.png</iPad_Launch1024x768>
|
||||
<iPad_Launch1536x2048>$(BDS)\bin\Artwork\iOS\iPad\FM_LaunchImagePortrait_1536x2048.png</iPad_Launch1536x2048>
|
||||
<iPad_Launch2048x1536>$(BDS)\bin\Artwork\iOS\iPad\FM_LaunchImageLandscape_2048x1536.png</iPad_Launch2048x1536>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Base_iOSSimulator)'!=''">
|
||||
<iPhone_AppIcon60>$(BDS)\bin\Artwork\iOS\iPhone\FM_ApplicationIcon_60x60.png</iPhone_AppIcon60>
|
||||
<iPhone_AppIcon120>$(BDS)\bin\Artwork\iOS\iPhone\FM_ApplicationIcon_120x120.png</iPhone_AppIcon120>
|
||||
<iPhone_Spotlight40>$(BDS)\bin\Artwork\iOS\iPhone\FM_SpotlightSearchIcon_40x40.png</iPhone_Spotlight40>
|
||||
<iPhone_Spotlight80>$(BDS)\bin\Artwork\iOS\iPhone\FM_SpotlightSearchIcon_80x80.png</iPhone_Spotlight80>
|
||||
<iPad_SpotLight40>$(BDS)\bin\Artwork\iOS\iPad\FM_SpotlightSearchIcon_40x40.png</iPad_SpotLight40>
|
||||
<iPad_SpotLight80>$(BDS)\bin\Artwork\iOS\iPad\FM_SpotlightSearchIcon_80x80.png</iPad_SpotLight80>
|
||||
<iPad_AppIcon76>$(BDS)\bin\Artwork\iOS\iPad\FM_ApplicationIcon_76x76.png</iPad_AppIcon76>
|
||||
<iPad_AppIcon152>$(BDS)\bin\Artwork\iOS\iPad\FM_ApplicationIcon_152x152.png</iPad_AppIcon152>
|
||||
<iPad_Launch768x1024>$(BDS)\bin\Artwork\iOS\iPad\FM_LaunchImagePortrait_768x1024.png</iPad_Launch768x1024>
|
||||
<iPad_Launch1024x768>$(BDS)\bin\Artwork\iOS\iPad\FM_LaunchImageLandscape_1024x768.png</iPad_Launch1024x768>
|
||||
<iPad_Launch1536x2048>$(BDS)\bin\Artwork\iOS\iPad\FM_LaunchImagePortrait_1536x2048.png</iPad_Launch1536x2048>
|
||||
<iPad_Launch2048x1536>$(BDS)\bin\Artwork\iOS\iPad\FM_LaunchImageLandscape_2048x1536.png</iPad_Launch2048x1536>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Base_Win32)'!=''">
|
||||
<DCC_UsePackage>DBXSqliteDriver;fmxase;DBXDb2Driver;DBXInterBaseDriver;OverbyteIcsD102Run;vclactnband;vclFireDAC;tethering;svnui;FireDACADSDriver;rtcSDK;DBXMSSQLDriver;DatasnapConnectorsFreePascal;FireDACMSSQLDriver;vcltouch;PythonVCL_D;vcldb;bindcompfmx;svn;DBXOracleDriver;inetdb;MQTTComponents;VirtualTreesDR;RaizeComponentsVcl;emsedge;RaizeComponentsVclDb;fmx;fmxdae;FireDACDBXDriver;dbexpress;IndyCore;vclx;Python_D;dsnap;DataSnapCommon;Package1;DataSnapConnectors;VCLRESTComponents;JclDeveloperTools;vclie;bindengine;DBXMySQLDriver;FireDACOracleDriver;FireDACMySQLDriver;DBXFirebirdDriver;pasdoc_package_XE8;FireDACCommonODBC;DataSnapClient;rtcSDK_DBA;IndyIPCommon;bindcompdbx;vcl;IndyIPServer;DBXSybaseASEDriver;IndySystem;FireDACDb2Driver;dsnapcon;DMVC_IDE_Expert_D102Tokyo;FireDACMSAccDriver;fmxFireDAC;FireDACInfxDriver;vclimg;Jcl;emshosting;FireDACPgDriver;FireDACASADriver;DBXOdbcDriver;FireDACTDataDriver;DbxCommonDriver;DataSnapServer;xmlrtl;DataSnapNativeClient;fmxobj;vclwinx;FireDACDSDriver;rtl;RFindUnit;DbxClientDriver;DBXSybaseASADriver;CustomIPTransport;vcldsnap;SynEditDR;bindcomp;appanalytics;DBXInformixDriver;IndyIPClient;bindcompvcl;dbxcds;VclSmp;adortl;FireDACODBCDriver;JclVcl;DataSnapIndy10ServerTransport;dsnapxml;DataSnapProviderClient;dbrtl;IndyProtocols;inetdbxpress;FireDACMongoDBDriver;JclContainers;DataSnapServerMidas;$(DCC_UsePackage)</DCC_UsePackage>
|
||||
<DCC_Namespace>Winapi;System.Win;Data.Win;Datasnap.Win;Web.Win;Soap.Win;Xml.Win;Bde;$(DCC_Namespace)</DCC_Namespace>
|
||||
<BT_BuildType>Debug</BT_BuildType>
|
||||
<VerInfo_Keys>CompanyName=;FileDescription=$(MSBuildProjectName);FileVersion=1.0.0.0;InternalName=;LegalCopyright=;LegalTrademarks=;OriginalFilename=;ProductName=$(MSBuildProjectName);ProductVersion=1.0.0.0;Comments=;ProgramID=com.embarcadero.$(MSBuildProjectName)</VerInfo_Keys>
|
||||
<VerInfo_Locale>1033</VerInfo_Locale>
|
||||
<Manifest_File>(None)</Manifest_File>
|
||||
<DCC_ExeOutput>.\bin</DCC_ExeOutput>
|
||||
<Icon_MainIcon>activerecord_crud_Icon.ico</Icon_MainIcon>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Base_Win64)'!=''">
|
||||
<DCC_UsePackage>DBXSqliteDriver;fmxase;DBXDb2Driver;DBXInterBaseDriver;OverbyteIcsD102Run;vclactnband;vclFireDAC;tethering;FireDACADSDriver;DBXMSSQLDriver;DatasnapConnectorsFreePascal;FireDACMSSQLDriver;vcltouch;vcldb;bindcompfmx;DBXOracleDriver;inetdb;VirtualTreesDR;RaizeComponentsVcl;emsedge;RaizeComponentsVclDb;fmx;fmxdae;FireDACDBXDriver;dbexpress;IndyCore;vclx;dsnap;DataSnapCommon;DataSnapConnectors;VCLRESTComponents;vclie;bindengine;DBXMySQLDriver;FireDACOracleDriver;FireDACMySQLDriver;DBXFirebirdDriver;FireDACCommonODBC;DataSnapClient;IndyIPCommon;bindcompdbx;vcl;IndyIPServer;DBXSybaseASEDriver;IndySystem;FireDACDb2Driver;dsnapcon;FireDACMSAccDriver;fmxFireDAC;FireDACInfxDriver;vclimg;emshosting;FireDACPgDriver;FireDACASADriver;DBXOdbcDriver;FireDACTDataDriver;DbxCommonDriver;DataSnapServer;xmlrtl;DataSnapNativeClient;fmxobj;vclwinx;FireDACDSDriver;rtl;DbxClientDriver;DBXSybaseASADriver;CustomIPTransport;vcldsnap;SynEditDR;bindcomp;appanalytics;DBXInformixDriver;IndyIPClient;bindcompvcl;dbxcds;VclSmp;adortl;FireDACODBCDriver;DataSnapIndy10ServerTransport;dsnapxml;DataSnapProviderClient;dbrtl;IndyProtocols;inetdbxpress;FireDACMongoDBDriver;DataSnapServerMidas;$(DCC_UsePackage)</DCC_UsePackage>
|
||||
<DCC_Namespace>Winapi;System.Win;Data.Win;Datasnap.Win;Web.Win;Soap.Win;Xml.Win;$(DCC_Namespace)</DCC_Namespace>
|
||||
<BT_BuildType>Debug</BT_BuildType>
|
||||
<VerInfo_Locale>1033</VerInfo_Locale>
|
||||
<Icon_MainIcon>activerecord_crud_Icon.ico</Icon_MainIcon>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Cfg_1)'!=''">
|
||||
<DCC_Define>DEBUG;$(DCC_Define)</DCC_Define>
|
||||
<DCC_DebugDCUs>true</DCC_DebugDCUs>
|
||||
<DCC_Optimize>false</DCC_Optimize>
|
||||
<DCC_GenerateStackFrames>true</DCC_GenerateStackFrames>
|
||||
<DCC_DebugInfoInExe>true</DCC_DebugInfoInExe>
|
||||
<DCC_RemoteDebug>true</DCC_RemoteDebug>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Cfg_1_Win32)'!=''">
|
||||
<DCC_RemoteDebug>false</DCC_RemoteDebug>
|
||||
<VerInfo_Locale>1033</VerInfo_Locale>
|
||||
<DCC_MapFile>3</DCC_MapFile>
|
||||
<Debugger_RunParams>/postgresql</Debugger_RunParams>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Cfg_1_Win64)'!=''">
|
||||
<DCC_ExeOutput>.\bin</DCC_ExeOutput>
|
||||
<VerInfo_Locale>1033</VerInfo_Locale>
|
||||
<Manifest_File>(None)</Manifest_File>
|
||||
<DCC_Define>RELEASE;$(DCC_Define)</DCC_Define>
|
||||
<DCC_DebugInformation>0</DCC_DebugInformation>
|
||||
<DCC_LocalDebugSymbols>false</DCC_LocalDebugSymbols>
|
||||
<DCC_SymbolReferenceInfo>0</DCC_SymbolReferenceInfo>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Cfg_2)'!=''">
|
||||
<DCC_LocalDebugSymbols>false</DCC_LocalDebugSymbols>
|
||||
<DCC_Define>RELEASE;$(DCC_Define)</DCC_Define>
|
||||
<DCC_SymbolReferenceInfo>0</DCC_SymbolReferenceInfo>
|
||||
<DCC_DebugInformation>0</DCC_DebugInformation>
|
||||
<DCC_Define>DEBUG;$(DCC_Define)</DCC_Define>
|
||||
<DCC_Optimize>false</DCC_Optimize>
|
||||
<DCC_GenerateStackFrames>true</DCC_GenerateStackFrames>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Cfg_2_Android64)'!=''">
|
||||
<BT_BuildType>Debug</BT_BuildType>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition="'$(Cfg_2_OSX64)'!=''">
|
||||
<BT_BuildType>Debug</BT_BuildType>
|
||||
</PropertyGroup>
|
||||
<ItemGroup>
|
||||
<DelphiCompile Include="$(MainSource)">
|
||||
@ -140,737 +198,42 @@
|
||||
<DCCReference Include="..\..\sources\MVCFramework.ActiveRecord.pas"/>
|
||||
<DCCReference Include="EntitiesProcessors.pas"/>
|
||||
<DCCReference Include="..\activerecord_showcase\FDConnectionConfigU.pas"/>
|
||||
<BuildConfiguration Include="Release">
|
||||
<BuildConfiguration Include="Debug">
|
||||
<Key>Cfg_2</Key>
|
||||
<CfgParent>Base</CfgParent>
|
||||
</BuildConfiguration>
|
||||
<BuildConfiguration Include="Base">
|
||||
<Key>Base</Key>
|
||||
</BuildConfiguration>
|
||||
<BuildConfiguration Include="Debug">
|
||||
<BuildConfiguration Include="Release">
|
||||
<Key>Cfg_1</Key>
|
||||
<CfgParent>Base</CfgParent>
|
||||
</BuildConfiguration>
|
||||
</ItemGroup>
|
||||
<ProjectExtensions>
|
||||
<Borland.Personality>Delphi.Personality.12</Borland.Personality>
|
||||
<Borland.ProjectType>Console</Borland.ProjectType>
|
||||
<Borland.ProjectType/>
|
||||
<BorlandProject>
|
||||
<Delphi.Personality>
|
||||
<Source>
|
||||
<Source Name="MainSource">activerecord_crud.dpr</Source>
|
||||
</Source>
|
||||
<Excluded_Packages>
|
||||
<Excluded_Packages Name="$(BDSBIN)\DataExplorerDBXPluginEnt260.bpl">DBExpress Enterprise Data Explorer Integration</Excluded_Packages>
|
||||
<Excluded_Packages Name="$(BDSBIN)\bcboffice2k260.bpl">Embarcadero C++Builder Office 2000 Servers Package</Excluded_Packages>
|
||||
<Excluded_Packages Name="$(BDSBIN)\bcbofficexp260.bpl">Embarcadero C++Builder Office XP Servers Package</Excluded_Packages>
|
||||
<Excluded_Packages Name="$(BDSBIN)\dcloffice2k260.bpl">Microsoft Office 2000 Sample Automation Server Wrapper Components</Excluded_Packages>
|
||||
<Excluded_Packages Name="$(BDSBIN)\dclofficexp260.bpl">Microsoft Office XP Sample Automation Server Wrapper Components</Excluded_Packages>
|
||||
</Excluded_Packages>
|
||||
</Delphi.Personality>
|
||||
<Deployment Version="3">
|
||||
<DeployFile LocalName="$(BDS)\Redist\osx32\libcgunwind.1.0.dylib" Class="DependencyModule">
|
||||
<Platform Name="OSX32">
|
||||
<Overwrite>true</Overwrite>
|
||||
</Platform>
|
||||
</DeployFile>
|
||||
<DeployFile LocalName="$(BDS)\Redist\iossimulator\libcgunwind.1.0.dylib" Class="DependencyModule">
|
||||
<Platform Name="iOSSimulator">
|
||||
<Overwrite>true</Overwrite>
|
||||
</Platform>
|
||||
</DeployFile>
|
||||
<DeployFile LocalName="$(BDS)\Redist\iossimulator\libPCRE.dylib" Class="DependencyModule">
|
||||
<Platform Name="iOSSimulator">
|
||||
<Overwrite>true</Overwrite>
|
||||
</Platform>
|
||||
</DeployFile>
|
||||
<DeployFile LocalName="$(BDS)\Redist\osx32\libcgsqlite3.dylib" Class="DependencyModule">
|
||||
<Platform Name="OSX32">
|
||||
<Overwrite>true</Overwrite>
|
||||
</Platform>
|
||||
</DeployFile>
|
||||
<DeployFile LocalName="Win32\Debug\activerecord_crud.exe" Configuration="Debug" Class="ProjectOutput">
|
||||
<Platform Name="Win32">
|
||||
<RemoteName>activerecord_crud.exe</RemoteName>
|
||||
<Overwrite>true</Overwrite>
|
||||
</Platform>
|
||||
</DeployFile>
|
||||
<DeployClass Name="AdditionalDebugSymbols">
|
||||
<Platform Name="OSX32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Win32">
|
||||
<Operation>0</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="AndroidClassesDexFile">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>classes</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="AndroidFileProvider">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\xml</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="AndroidGDBServer">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>library\lib\armeabi-v7a</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="AndroidLibnativeArmeabiFile">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>library\lib\armeabi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="AndroidLibnativeMipsFile">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>library\lib\mips</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="AndroidServiceOutput">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>library\lib\armeabi-v7a</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="AndroidSplashImageDef">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="AndroidSplashStyles">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\values</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="AndroidSplashStylesV21">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\values-v21</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_Colors">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\values</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_DefaultAppIcon">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_LauncherIcon144">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-xxhdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_LauncherIcon36">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-ldpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_LauncherIcon48">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-mdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_LauncherIcon72">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-hdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_LauncherIcon96">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-xhdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_NotificationIcon24">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-mdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_NotificationIcon36">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-hdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_NotificationIcon48">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-xhdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_NotificationIcon72">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-xxhdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_NotificationIcon96">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-xxxhdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_SplashImage426">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-small</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_SplashImage470">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-normal</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_SplashImage640">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-large</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_SplashImage960">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-xlarge</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_Strings">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\values</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="DebugSymbols">
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="OSX32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Win32">
|
||||
<Operation>0</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="DependencyFramework">
|
||||
<Platform Name="OSX32">
|
||||
<Operation>1</Operation>
|
||||
<Extensions>.framework</Extensions>
|
||||
</Platform>
|
||||
<Platform Name="OSX64">
|
||||
<Operation>1</Operation>
|
||||
<Extensions>.framework</Extensions>
|
||||
</Platform>
|
||||
<Platform Name="Win32">
|
||||
<Operation>0</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="DependencyModule">
|
||||
<Platform Name="OSX32">
|
||||
<Operation>1</Operation>
|
||||
<Extensions>.dylib</Extensions>
|
||||
</Platform>
|
||||
<Platform Name="OSX64">
|
||||
<Operation>1</Operation>
|
||||
<Extensions>.dylib</Extensions>
|
||||
</Platform>
|
||||
<Platform Name="Win32">
|
||||
<Operation>0</Operation>
|
||||
<Extensions>.dll;.bpl</Extensions>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Required="true" Name="DependencyPackage">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
<Extensions>.dylib</Extensions>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
<Extensions>.dylib</Extensions>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
<Extensions>.dylib</Extensions>
|
||||
</Platform>
|
||||
<Platform Name="OSX32">
|
||||
<Operation>1</Operation>
|
||||
<Extensions>.dylib</Extensions>
|
||||
</Platform>
|
||||
<Platform Name="OSX64">
|
||||
<Operation>1</Operation>
|
||||
<Extensions>.dylib</Extensions>
|
||||
</Platform>
|
||||
<Platform Name="Win32">
|
||||
<Operation>0</Operation>
|
||||
<Extensions>.bpl</Extensions>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="File">
|
||||
<Platform Name="Android">
|
||||
<Operation>0</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>0</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>0</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>0</Operation>
|
||||
</Platform>
|
||||
<Platform Name="OSX32">
|
||||
<Operation>0</Operation>
|
||||
</Platform>
|
||||
<Platform Name="OSX64">
|
||||
<Operation>0</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Win32">
|
||||
<Operation>0</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPad_Launch1024">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPad_Launch1024x768">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPad_Launch1536">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPad_Launch1536x2048">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPad_Launch1668">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPad_Launch1668x2388">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPad_Launch2048">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPad_Launch2048x1536">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPad_Launch2048x2732">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPad_Launch2224">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPad_Launch2388x1668">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPad_Launch2732x2048">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPad_Launch768">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPad_Launch768x1024">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPhone_Launch1125">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPhone_Launch1136x640">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPhone_Launch1242">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPhone_Launch1242x2688">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPhone_Launch1334">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPhone_Launch1792">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPhone_Launch2208">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPhone_Launch2436">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPhone_Launch2688x1242">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPhone_Launch320">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPhone_Launch640">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPhone_Launch640x1136">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPhone_Launch750">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="iPhone_Launch828">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="ProjectAndroidManifest">
|
||||
<Platform Name="Android">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="ProjectiOSDeviceDebug">
|
||||
<Platform Name="iOSDevice32">
|
||||
<RemoteDir>..\$(PROJECTNAME).app.dSYM\Contents\Resources\DWARF</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<RemoteDir>..\$(PROJECTNAME).app.dSYM\Contents\Resources\DWARF</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="ProjectiOSDeviceResourceRules"/>
|
||||
<DeployClass Name="ProjectiOSEntitlements"/>
|
||||
<DeployClass Name="ProjectiOSInfoPList"/>
|
||||
<DeployClass Name="ProjectiOSResource">
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="ProjectOSXDebug"/>
|
||||
<DeployClass Name="ProjectOSXEntitlements"/>
|
||||
<DeployClass Name="ProjectOSXInfoPList"/>
|
||||
<DeployClass Name="ProjectOSXResource">
|
||||
<Platform Name="OSX32">
|
||||
<RemoteDir>Contents\Resources</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="OSX64">
|
||||
<RemoteDir>Contents\Resources</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Required="true" Name="ProjectOutput">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>library\lib\armeabi-v7a</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSSimulator">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Linux64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="OSX32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="OSX64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Win32">
|
||||
<Operation>0</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="ProjectUWPManifest">
|
||||
<Platform Name="Win32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Win64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="UWP_DelphiLogo150">
|
||||
<Platform Name="Win32">
|
||||
<RemoteDir>Assets</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Win64">
|
||||
<RemoteDir>Assets</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="UWP_DelphiLogo44">
|
||||
<Platform Name="Win32">
|
||||
<RemoteDir>Assets</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Win64">
|
||||
<RemoteDir>Assets</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<ProjectRoot Platform="iOSDevice64" Name="$(PROJECTNAME).app"/>
|
||||
<ProjectRoot Platform="Win64" Name="$(PROJECTNAME)"/>
|
||||
<ProjectRoot Platform="iOSDevice32" Name="$(PROJECTNAME).app"/>
|
||||
<ProjectRoot Platform="Linux64" Name="$(PROJECTNAME)"/>
|
||||
<ProjectRoot Platform="Win32" Name="$(PROJECTNAME)"/>
|
||||
<ProjectRoot Platform="OSX32" Name="$(PROJECTNAME)"/>
|
||||
<ProjectRoot Platform="Android" Name="$(PROJECTNAME)"/>
|
||||
<ProjectRoot Platform="OSX64" Name="$(PROJECTNAME)"/>
|
||||
<ProjectRoot Platform="iOSSimulator" Name="$(PROJECTNAME).app"/>
|
||||
</Deployment>
|
||||
<Platforms>
|
||||
<Platform value="Android">False</Platform>
|
||||
<Platform value="Linux64">False</Platform>
|
||||
<Platform value="Android64">True</Platform>
|
||||
<Platform value="iOSDevice32">False</Platform>
|
||||
<Platform value="iOSDevice64">False</Platform>
|
||||
<Platform value="iOSSimulator">False</Platform>
|
||||
<Platform value="Linux64">True</Platform>
|
||||
<Platform value="OSX32">False</Platform>
|
||||
<Platform value="OSX64">True</Platform>
|
||||
<Platform value="Win32">True</Platform>
|
||||
<Platform value="Win64">True</Platform>
|
||||
<Platform value="Win64">False</Platform>
|
||||
</Platforms>
|
||||
</BorlandProject>
|
||||
<ProjectFileVersion>12</ProjectFileVersion>
|
||||
</ProjectExtensions>
|
||||
<Import Project="$(BDS)\Bin\CodeGear.Delphi.Targets" Condition="Exists('$(BDS)\Bin\CodeGear.Delphi.Targets')"/>
|
||||
<Import Project="$(APPDATA)\Embarcadero\$(BDSAPPDATABASEDIR)\$(PRODUCTVERSION)\UserTools.proj" Condition="Exists('$(APPDATA)\Embarcadero\$(BDSAPPDATABASEDIR)\$(PRODUCTVERSION)\UserTools.proj')"/>
|
||||
<Import Project="$(MSBuildProjectName).deployproj" Condition="Exists('$(MSBuildProjectName).deployproj')"/>
|
||||
</Project>
|
||||
|
@ -512,6 +512,7 @@ var
|
||||
lCustomers: TObjectList<TCustomer>;
|
||||
lCustomer: TCustomer;
|
||||
lDS: TDataSet;
|
||||
lID: NullableInt64;
|
||||
begin
|
||||
Log('** Query SQL');
|
||||
// Bypassing the RQL parser you can use DBMS-specific features or just joining your tables.
|
||||
@ -551,6 +552,23 @@ begin
|
||||
lDS.Free;
|
||||
end;
|
||||
|
||||
Log('** GetFirstByWhere');
|
||||
lCustomer := TMVCActiveRecord.GetFirstByWhere<TCustomer>('id > ?', [1]);
|
||||
try
|
||||
Log(Format('%8.5s - %s', [lCustomer.Code.ValueOrDefault, lCustomer.CompanyName.ValueOrDefault]));
|
||||
lID := lCustomer.ID;
|
||||
finally
|
||||
lCustomer.Free;
|
||||
end;
|
||||
|
||||
Log('** GetOneByWhere');
|
||||
lCustomer := TMVCActiveRecord.GetOneByWhere<TCustomer>('id = ?', [lID.Value]);
|
||||
try
|
||||
Log(Format('%8.5s - %s', [lCustomer.Code.ValueOrDefault, lCustomer.CompanyName.ValueOrDefault]));
|
||||
finally
|
||||
lCustomer.Free;
|
||||
end;
|
||||
|
||||
end;
|
||||
|
||||
procedure TMainForm.btnTransientFieldsClick(Sender: TObject);
|
||||
|
@ -3,7 +3,7 @@ unit BusinessObjects;
|
||||
interface
|
||||
|
||||
uses
|
||||
MVCFramework.Serializer.Commons;
|
||||
MVCFramework.Serializer.Commons, MVCFramework.Nullables;
|
||||
|
||||
type
|
||||
TBaseBO = class
|
||||
@ -22,9 +22,9 @@ type
|
||||
private
|
||||
FPrice: Currency;
|
||||
FCode: string;
|
||||
FDescription: string;
|
||||
FDescription: String;
|
||||
procedure SetCode(const Value: string);
|
||||
procedure SetDescription(const Value: string);
|
||||
procedure SetDescription(const Value: String);
|
||||
procedure SetPrice(const Value: Currency);
|
||||
public
|
||||
procedure CheckInsert; override;
|
||||
@ -33,7 +33,7 @@ type
|
||||
[MVCColumn('CODICE')]
|
||||
property Code: string read FCode write SetCode;
|
||||
[MVCColumn('DESCRIZIONE')]
|
||||
property Description: string read FDescription write SetDescription;
|
||||
property Description: String read FDescription write SetDescription;
|
||||
[MVCColumn('PREZZO')]
|
||||
property Price: Currency read FPrice write SetPrice;
|
||||
end;
|
||||
@ -94,7 +94,7 @@ begin
|
||||
FCode := Value;
|
||||
end;
|
||||
|
||||
procedure TArticle.SetDescription(const Value: string);
|
||||
procedure TArticle.SetDescription(const Value: String);
|
||||
begin
|
||||
FDescription := Value;
|
||||
end;
|
||||
|
@ -14,7 +14,8 @@ uses
|
||||
Services in 'Services.pas',
|
||||
BusinessObjects in 'BusinessObjects.pas',
|
||||
MainDM in 'MainDM.pas' {dmMain: TDataModule},
|
||||
Commons in 'Commons.pas';
|
||||
Commons in 'Commons.pas',
|
||||
MVCFramework.ActiveRecord in '..\..\sources\MVCFramework.ActiveRecord.pas';
|
||||
|
||||
{$R *.res}
|
||||
|
||||
|
@ -104,6 +104,7 @@
|
||||
<DesignClass>TDataModule</DesignClass>
|
||||
</DCCReference>
|
||||
<DCCReference Include="Commons.pas"/>
|
||||
<DCCReference Include="..\..\sources\MVCFramework.ActiveRecord.pas"/>
|
||||
<None Include="ModelSupport_ordersmanager\default.txvpck"/>
|
||||
<None Include="ModelSupport_ordersmanager\Services\default.txvpck"/>
|
||||
<None Include="ModelSupport_ordersmanager\ordersmanager\default.txvpck"/>
|
||||
|
@ -35,8 +35,8 @@ type
|
||||
procedure dsArticlesBeforeRowRequest(DataSet: TFDDataSet);
|
||||
procedure btnRefreshRecordClick(Sender: TObject);
|
||||
private
|
||||
FLoading: Boolean;
|
||||
Clt: TRESTClient;
|
||||
fLoading: Boolean;
|
||||
fRESTClient: TRESTClient;
|
||||
{ Private declarations }
|
||||
procedure ShowError(const AResponse: IRESTResponse);
|
||||
end;
|
||||
@ -72,7 +72,7 @@ var
|
||||
Res: IRESTResponse;
|
||||
begin
|
||||
// this a simple sychronous request...
|
||||
Res := Clt.doGET('/articles', []);
|
||||
Res := fRESTClient.doGET('/articles', []);
|
||||
if Res.HasError then
|
||||
begin
|
||||
ShowError(Res);
|
||||
@ -81,9 +81,9 @@ begin
|
||||
|
||||
DataSet.DisableControls;
|
||||
try
|
||||
FLoading := true;
|
||||
fLoading := true;
|
||||
dsArticles.LoadFromJSONArrayString(Res.BodyAsString);
|
||||
FLoading := false;
|
||||
fLoading := false;
|
||||
dsArticles.First;
|
||||
finally
|
||||
DataSet.EnableControls;
|
||||
@ -95,7 +95,7 @@ var
|
||||
Res: IRESTResponse;
|
||||
begin
|
||||
if dsArticles.State = dsBrowse then
|
||||
Res := Clt.DataSetDelete('/articles', dsArticlesid.AsString);
|
||||
Res := fRESTClient.DataSetDelete('/articles', dsArticlesid.AsString);
|
||||
if not(Res.ResponseCode in [200]) then
|
||||
begin
|
||||
ShowError(Res);
|
||||
@ -107,19 +107,21 @@ procedure TMainForm.dsArticlesBeforePost(DataSet: TDataSet);
|
||||
var
|
||||
Res: IRESTResponse;
|
||||
begin
|
||||
if not FLoading then
|
||||
if not fLoading then
|
||||
begin
|
||||
if dsArticles.State = dsInsert then
|
||||
Res := Clt.DataSetInsert('/articles', dsArticles)
|
||||
Res := fRESTClient.DataSetInsert('/articles', dsArticles)
|
||||
else
|
||||
Res := Clt.DataSetUpdate('/articles', dsArticles, dsArticlesid.AsString);
|
||||
Res := fRESTClient.DataSetUpdate('/articles', dsArticles, dsArticlesid.AsString);
|
||||
if not(Res.ResponseCode in [200, 201]) then
|
||||
begin
|
||||
ShowError(Res);
|
||||
Abort;
|
||||
end
|
||||
else
|
||||
begin
|
||||
DataSet.Refresh;
|
||||
end;
|
||||
end;
|
||||
end;
|
||||
|
||||
@ -133,20 +135,20 @@ procedure TMainForm.dsArticlesBeforeRowRequest(DataSet: TFDDataSet);
|
||||
var
|
||||
Res: IRESTResponse;
|
||||
begin
|
||||
Res := Clt.doGET('/articles', [DataSet.FieldByName('id').AsString]);
|
||||
FLoading := true;
|
||||
Res := fRESTClient.doGET('/articles', [DataSet.FieldByName('id').AsString]);
|
||||
fLoading := true;
|
||||
DataSet.LoadFromJSONObjectString(Res.BodyAsString);
|
||||
FLoading := false;
|
||||
fLoading := false;
|
||||
end;
|
||||
|
||||
procedure TMainForm.FormClose(Sender: TObject; var Action: TCloseAction);
|
||||
begin
|
||||
Clt.Free;
|
||||
fRESTClient.Free;
|
||||
end;
|
||||
|
||||
procedure TMainForm.FormCreate(Sender: TObject);
|
||||
begin
|
||||
Clt := MVCFramework.RESTClient.TRESTClient.Create('localhost', 8080);
|
||||
fRESTClient := MVCFramework.RESTClient.TRESTClient.Create('localhost', 8080);
|
||||
end;
|
||||
|
||||
procedure TMainForm.ShowError(const AResponse: IRESTResponse);
|
||||
|
@ -31,7 +31,9 @@ uses
|
||||
MVCFramework.Nullables,
|
||||
MVCFramework.ActiveRecord,
|
||||
System.Generics.Collections,
|
||||
{$IFNDEF LINUX}
|
||||
Vcl.Graphics,
|
||||
{$ENDIF}
|
||||
JsonDataObjects, System.Classes;
|
||||
|
||||
type
|
||||
@ -206,14 +208,18 @@ type
|
||||
FContactFirst: string;
|
||||
FCity: string;
|
||||
FContactLast: string;
|
||||
{$IFNDEF LINUX}
|
||||
fLogo: TBitmap;
|
||||
{$ENDIF}
|
||||
procedure SetAddressLine1(const Value: string);
|
||||
procedure SetAddressLine2(const Value: string);
|
||||
procedure SetCity(const Value: string);
|
||||
procedure SetContactFirst(const Value: string);
|
||||
procedure SetContactLast(const Value: string);
|
||||
procedure SetName(const Value: string);
|
||||
{$IFNDEF LINUX}
|
||||
procedure SetLogo(const Value: TBitmap);
|
||||
{$ENDIF}
|
||||
public
|
||||
constructor Create;
|
||||
destructor Destroy; override;
|
||||
@ -225,7 +231,9 @@ type
|
||||
property AddressLine1: string read FAddressLine1 write SetAddressLine1;
|
||||
property AddressLine2: string read FAddressLine2 write SetAddressLine2;
|
||||
property City: string read FCity write SetCity;
|
||||
{$IFNDEF LINUX}
|
||||
property Logo: TBitmap read fLogo write SetLogo;
|
||||
{$ENDIF}
|
||||
class function GetList: TObjectList<TCustomer>;
|
||||
end;
|
||||
|
||||
@ -335,12 +343,16 @@ end;
|
||||
constructor TCustomer.Create;
|
||||
begin
|
||||
inherited;
|
||||
{$IFNDEF LINUX}
|
||||
fLogo := TBitmap.Create;
|
||||
{$ENDIF}
|
||||
end;
|
||||
|
||||
destructor TCustomer.Destroy;
|
||||
begin
|
||||
{$IFNDEF LINUX}
|
||||
fLogo.Free;
|
||||
{$ENDIF}
|
||||
inherited;
|
||||
end;
|
||||
|
||||
@ -404,10 +416,14 @@ begin
|
||||
FContactLast := Value;
|
||||
end;
|
||||
|
||||
{$IFNDEF LINUX}
|
||||
|
||||
procedure TCustomer.SetLogo(const Value: TBitmap);
|
||||
begin
|
||||
fLogo := Value;
|
||||
end;
|
||||
{$ENDIF}
|
||||
|
||||
|
||||
procedure TCustomer.SetName(const Value: string);
|
||||
begin
|
||||
|
Binary file not shown.
Binary file not shown.
@ -32,10 +32,11 @@ implementation
|
||||
|
||||
uses
|
||||
Web.WebReq,
|
||||
WebModuleUnit1;
|
||||
WebModuleUnit1, MVCFramework.Commons;
|
||||
|
||||
{$R *.DFM}
|
||||
|
||||
|
||||
procedure ServiceController(CtrlCode: DWord); stdcall;
|
||||
begin
|
||||
ArticlesService.Controller(CtrlCode);
|
||||
|
@ -1,7 +1,7 @@
|
||||
<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||
<PropertyGroup>
|
||||
<ProjectGuid>{45323E7F-B291-46C5-9D32-F467DD8D8E5D}</ProjectGuid>
|
||||
<ProjectVersion>18.7</ProjectVersion>
|
||||
<ProjectVersion>18.8</ProjectVersion>
|
||||
<FrameworkType>VCL</FrameworkType>
|
||||
<MainSource>dmvcwindowsservice.dpr</MainSource>
|
||||
<Base>True</Base>
|
||||
@ -201,12 +201,20 @@
|
||||
<RemoteDir>classes</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>classes</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="AndroidFileProvider">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\xml</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>res\xml</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="AndroidGDBServer">
|
||||
<Platform Name="Android">
|
||||
@ -219,138 +227,242 @@
|
||||
<RemoteDir>library\lib\armeabi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>library\lib\armeabi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="AndroidLibnativeArmeabiv7aFile">
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>library\lib\armeabi-v7a</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="AndroidLibnativeMipsFile">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>library\lib\mips</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>library\lib\mips</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="AndroidServiceOutput">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>library\lib\armeabi-v7a</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>library\lib\arm64-v8a</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="AndroidServiceOutput_Android32">
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>library\lib\armeabi-v7a</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="AndroidSplashImageDef">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>res\drawable</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="AndroidSplashStyles">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\values</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>res\values</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="AndroidSplashStylesV21">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\values-v21</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>res\values-v21</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_Colors">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\values</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>res\values</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_DefaultAppIcon">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>res\drawable</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_LauncherIcon144">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-xxhdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>res\drawable-xxhdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_LauncherIcon36">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-ldpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>res\drawable-ldpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_LauncherIcon48">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-mdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>res\drawable-mdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_LauncherIcon72">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-hdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>res\drawable-hdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_LauncherIcon96">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-xhdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>res\drawable-xhdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_NotificationIcon24">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-mdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>res\drawable-mdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_NotificationIcon36">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-hdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>res\drawable-hdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_NotificationIcon48">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-xhdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>res\drawable-xhdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_NotificationIcon72">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-xxhdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>res\drawable-xxhdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_NotificationIcon96">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-xxxhdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>res\drawable-xxxhdpi</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_SplashImage426">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-small</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>res\drawable-small</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_SplashImage470">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-normal</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>res\drawable-normal</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_SplashImage640">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-large</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>res\drawable-large</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_SplashImage960">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\drawable-xlarge</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>res\drawable-xlarge</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="Android_Strings">
|
||||
<Platform Name="Android">
|
||||
<RemoteDir>res\values</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>res\values</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="DebugSymbols">
|
||||
<Platform Name="iOSSimulator">
|
||||
@ -439,6 +551,9 @@
|
||||
<Platform Name="Android">
|
||||
<Operation>0</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<Operation>0</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>0</Operation>
|
||||
</Platform>
|
||||
@ -772,6 +887,9 @@
|
||||
<Platform Name="Android">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="ProjectiOSDeviceDebug">
|
||||
<Platform Name="iOSDevice32">
|
||||
@ -864,6 +982,10 @@
|
||||
<RemoteDir>library\lib\armeabi-v7a</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>library\lib\arm64-v8a</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
<Platform Name="iOSDevice32">
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
@ -888,6 +1010,12 @@
|
||||
<Operation>0</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="ProjectOutput_Android32">
|
||||
<Platform Name="Android64">
|
||||
<RemoteDir>library\lib\armeabi-v7a</RemoteDir>
|
||||
<Operation>1</Operation>
|
||||
</Platform>
|
||||
</DeployClass>
|
||||
<DeployClass Name="ProjectUWPManifest">
|
||||
<Platform Name="Win32">
|
||||
<Operation>1</Operation>
|
||||
@ -925,6 +1053,7 @@
|
||||
<ProjectRoot Platform="Android" Name="$(PROJECTNAME)"/>
|
||||
<ProjectRoot Platform="OSX64" Name="$(PROJECTNAME).app"/>
|
||||
<ProjectRoot Platform="iOSSimulator" Name="$(PROJECTNAME).app"/>
|
||||
<ProjectRoot Platform="Android64" Name="$(PROJECTNAME)"/>
|
||||
</Deployment>
|
||||
<Platforms>
|
||||
<Platform value="Win32">True</Platform>
|
||||
|
@ -126,9 +126,6 @@ type
|
||||
fPrimaryKeySequenceName: String;
|
||||
fEntityAllowedActions: TMVCEntityActions;
|
||||
fRQL2SQL: TRQL2SQL;
|
||||
procedure MapColumnToTValue(const aFieldName: string; const aField: TField; const aRTTIField: TRttiField);
|
||||
function MapNullableColumnToTValue(const aValue: TValue;
|
||||
const aField: TField; const aRTTIField: TRttiField): Boolean;
|
||||
procedure MapTValueToParam(aValue: TValue; const aParam: TFDParam);
|
||||
function MapNullableTValueToParam(aValue: TValue;
|
||||
const aParam: TFDParam): Boolean;
|
||||
@ -755,7 +752,7 @@ begin
|
||||
|
||||
if (lValue.Kind = tkRecord) then
|
||||
begin
|
||||
MapNullableColumnToTValue(lValue, lQry.Fields[0], fPrimaryKey);
|
||||
MapDataSetFieldToNullableRTTIField(lValue, lQry.Fields[0], fPrimaryKey, Self);
|
||||
// if SameText(lValue.TypeInfo.Name, 'Nullable<System.Integer>') then
|
||||
// begin
|
||||
// lInteger :=lQry.FieldByName(fPrimaryKeyFieldName).AsInteger;
|
||||
@ -848,7 +845,7 @@ begin
|
||||
end;
|
||||
lDS := ExecQuery(lSQL, []);
|
||||
try
|
||||
MapColumnToTValue(fPrimaryKeyFieldName, lDS.Fields[0], fPrimaryKey);
|
||||
MapDataSetFieldToRTTIField(lDS.Fields[0], fPrimaryKey, Self);
|
||||
finally
|
||||
lDS.Free;
|
||||
end;
|
||||
@ -1057,7 +1054,7 @@ begin
|
||||
raise EMVCActiveRecord.Create('Got 0 rows');
|
||||
Exit(nil);
|
||||
end;
|
||||
Result := lList.ExtractAt(0);
|
||||
Result := lList.Extract(lList.First);
|
||||
finally
|
||||
lList.Free;
|
||||
end;
|
||||
@ -1215,311 +1212,6 @@ begin
|
||||
end;
|
||||
end;
|
||||
|
||||
function TMVCActiveRecord.MapNullableColumnToTValue(const aValue: TValue; const aField: TField;
|
||||
const aRTTIField: TRttiField): Boolean;
|
||||
begin
|
||||
Assert(aValue.Kind = tkRecord);
|
||||
Result := false;
|
||||
if aValue.IsType(TypeInfo(NullableString)) then
|
||||
begin
|
||||
if aField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(Self).AsType<NullableString>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(Self, TValue.From<NullableString>(aField.AsString));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if aValue.IsType(TypeInfo(NullableInt32)) then
|
||||
begin
|
||||
if aField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(Self).AsType<NullableInt32>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(Self, TValue.From<NullableInt32>(aField.AsLargeInt));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if aValue.IsType(TypeInfo(NullableUInt32)) then
|
||||
begin
|
||||
if aField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(Self).AsType<NullableUInt32>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(Self, TValue.From<NullableUInt32>(aField.AsLargeInt));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if aValue.IsType(TypeInfo(NullableInt64)) then
|
||||
begin
|
||||
if aField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(Self).AsType<NullableInt64>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(Self, TValue.From<NullableInt64>(aField.AsLargeInt));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if aValue.IsType(TypeInfo(NullableUInt64)) then
|
||||
begin
|
||||
if aField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(Self).AsType<NullableUInt64>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(Self, TValue.From<NullableUInt64>(aField.AsLargeInt));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if aValue.IsType(TypeInfo(NullableInt16)) then
|
||||
begin
|
||||
if aField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(Self).AsType<NullableInt16>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(Self, TValue.From<NullableInt16>(aField.AsLargeInt));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if aValue.IsType(TypeInfo(NullableUInt16)) then
|
||||
begin
|
||||
if aField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(Self).AsType<NullableUInt16>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(Self, TValue.From<NullableUInt16>(aField.AsInteger));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if aValue.IsType(TypeInfo(NullableTDate)) then
|
||||
begin
|
||||
if aField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(Self).AsType<NullableTDate>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(Self, TValue.From<NullableTDate>(aField.AsDateTime));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if aValue.IsType(TypeInfo(NullableTDateTime)) then
|
||||
begin
|
||||
if aField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(Self).AsType<NullableTDateTime>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(Self, TValue.From<NullableTDateTime>(aField.AsDateTime));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if aValue.IsType(TypeInfo(NullableTTime)) then
|
||||
begin
|
||||
if aField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(Self).AsType<NullableTTime>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(Self, TValue.From<NullableTTime>(aField.AsDateTime));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if aValue.IsType(TypeInfo(NullableBoolean)) then
|
||||
begin
|
||||
if aField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(Self).AsType<NullableBoolean>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(Self, TValue.From<NullableBoolean>(aField.AsBoolean));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if aValue.IsType(TypeInfo(NullableDouble)) then
|
||||
begin
|
||||
if aField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(Self).AsType<NullableDouble>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(Self, TValue.From<NullableDouble>(aField.AsFloat));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if aValue.IsType(TypeInfo(NullableSingle)) then
|
||||
begin
|
||||
if aField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(Self).AsType<NullableSingle>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(Self, TValue.From<NullableSingle>(aField.AsSingle));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if aValue.IsType(TypeInfo(NullableExtended)) then
|
||||
begin
|
||||
if aField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(Self).AsType<NullableExtended>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(Self, TValue.From<NullableExtended>(aField.AsExtended));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if aValue.IsType(TypeInfo(NullableCurrency)) then
|
||||
begin
|
||||
if aField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(Self).AsType<NullableCurrency>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(Self, TValue.From<NullableCurrency>(aField.AsCurrency));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
end;
|
||||
|
||||
procedure TMVCActiveRecord.MapColumnToTValue(const aFieldName: string; const aField: TField;
|
||||
const aRTTIField: TRttiField);
|
||||
var
|
||||
lInternalStream: TStream;
|
||||
lSStream: TStringStream;
|
||||
lValue: TValue;
|
||||
begin
|
||||
lValue := aRTTIField.GetValue(Self);
|
||||
if lValue.Kind = tkRecord then
|
||||
begin
|
||||
if MapNullableColumnToTValue(lValue, aField, aRTTIField) then
|
||||
begin
|
||||
Exit;
|
||||
end;
|
||||
end;
|
||||
|
||||
// if we reached this point, the field is not a nullable type...
|
||||
case aField.DataType of
|
||||
ftString, ftWideString:
|
||||
begin
|
||||
aRTTIField.SetValue(Self, aField.AsString);
|
||||
end;
|
||||
ftLargeint, ftAutoInc:
|
||||
begin
|
||||
aRTTIField.SetValue(Self, aField.AsLargeInt);
|
||||
end;
|
||||
ftInteger, ftSmallint, ftShortint:
|
||||
begin
|
||||
aRTTIField.SetValue(Self, aField.AsInteger);
|
||||
end;
|
||||
ftLongWord, ftWord:
|
||||
begin
|
||||
aRTTIField.SetValue(Self, aField.AsLongWord);
|
||||
end;
|
||||
ftFMTBcd:
|
||||
begin
|
||||
aRTTIField.SetValue(Self, BCDtoCurrency(aField.AsBCD));
|
||||
end;
|
||||
ftDate:
|
||||
begin
|
||||
aRTTIField.SetValue(Self, Trunc(aField.AsDateTime));
|
||||
end;
|
||||
ftDateTime:
|
||||
begin
|
||||
aRTTIField.SetValue(Self, Trunc(aField.AsDateTime));
|
||||
end;
|
||||
ftTimeStamp:
|
||||
begin
|
||||
aRTTIField.SetValue(Self, aField.AsDateTime);
|
||||
end;
|
||||
ftBoolean:
|
||||
begin
|
||||
aRTTIField.SetValue(Self, aField.AsBoolean);
|
||||
end;
|
||||
ftMemo, ftWideMemo:
|
||||
begin
|
||||
if aRTTIField.FieldType.TypeKind in [tkString, tkUString { , tkWideString } ] then
|
||||
begin
|
||||
// In case you want to map a "TEXT" blob into a Delphi String
|
||||
lSStream := TStringStream.Create('', TEncoding.Unicode);
|
||||
try
|
||||
TBlobField(aField).SaveToStream(lSStream);
|
||||
aRTTIField.SetValue(Self, lSStream.DataString);
|
||||
finally
|
||||
lSStream.Free;
|
||||
end;
|
||||
end
|
||||
else
|
||||
begin
|
||||
// In case you want to map a binary blob into a Delphi Stream
|
||||
lInternalStream := aRTTIField.GetValue(Self).AsObject as TStream;
|
||||
if lInternalStream = nil then
|
||||
begin
|
||||
raise EMVCActiveRecord.CreateFmt('Property target for %s field is nil', [aFieldName]);
|
||||
end;
|
||||
lInternalStream.Position := 0;
|
||||
TBlobField(aField).SaveToStream(lInternalStream);
|
||||
lInternalStream.Position := 0;
|
||||
end;
|
||||
end;
|
||||
ftBCD:
|
||||
begin
|
||||
aRTTIField.SetValue(Self, BCDtoCurrency(aField.AsBCD));
|
||||
end;
|
||||
ftFloat:
|
||||
begin
|
||||
aRTTIField.SetValue(Self, aField.AsFloat);
|
||||
end;
|
||||
ftBlob:
|
||||
begin
|
||||
lInternalStream := aRTTIField.GetValue(Self).AsObject as TStream;
|
||||
if aField.IsNull then
|
||||
begin
|
||||
lInternalStream.Free;
|
||||
aRTTIField.SetValue(Self, nil);
|
||||
Exit;
|
||||
end;
|
||||
if lInternalStream = nil then
|
||||
begin
|
||||
lInternalStream := TMemoryStream.Create;
|
||||
aRTTIField.SetValue(Self, lInternalStream);
|
||||
// raise EMVCActiveRecord.CreateFmt('Property target for %s field is nil', [aFieldName]);
|
||||
end;
|
||||
lInternalStream.Position := 0;
|
||||
TBlobField(aField).SaveToStream(lInternalStream);
|
||||
lInternalStream.Position := 0;
|
||||
end;
|
||||
{$IF Defined(SeattleOrBetter)}
|
||||
ftGuid:
|
||||
begin
|
||||
aRTTIField.SetValue(Self, TValue.From<TGUID>(aField.AsGuid));
|
||||
end;
|
||||
{$ENDIF}
|
||||
else
|
||||
raise EMVCActiveRecord.CreateFmt('Unsupported FieldType (%d) for field %s', [Ord(aField.DataType), aFieldName]);
|
||||
end;
|
||||
|
||||
end;
|
||||
|
||||
procedure TMVCActiveRecord.MapDatasetToObject(const DataSet: TDataSet;
|
||||
const Options: TMVCActiveRecordLoadOptions;
|
||||
@ -1992,11 +1684,11 @@ begin
|
||||
('Field [%s] not found in dataset. [HINT] If you dont need it, use loIgnoreNotExistentFields',
|
||||
[lItem.Value]);
|
||||
end;
|
||||
MapColumnToTValue(lItem.Value, lField, lItem.Key);
|
||||
MapDataSetFieldToRTTIField(lField, lItem.Key, Self);
|
||||
end;
|
||||
if not fPrimaryKeyFieldName.IsEmpty then
|
||||
begin
|
||||
MapColumnToTValue(fPrimaryKeyFieldName, aDataSet.FieldByName(fPrimaryKeyFieldName), fPrimaryKey);
|
||||
MapDataSetFieldToRTTIField(aDataSet.FieldByName(fPrimaryKeyFieldName), fPrimaryKey, Self);
|
||||
end;
|
||||
end;
|
||||
OnAfterLoad;
|
||||
|
@ -63,7 +63,8 @@ type
|
||||
AFieldNamePolicy: TFieldNamePolicy = TFieldNamePolicy.fpLowerCase); overload;
|
||||
procedure LoadFromJSONObjectString(AJSONObjectString: string); overload;
|
||||
procedure LoadFromJSONObjectString(AJSONObjectString: string; AIgnoredFields: TArray<string>); overload;
|
||||
procedure LoadJSONArrayFromJSONObjectProperty(const AJSONObjectString: string; const aPropertyName: String; const aFieldNamePolicy: TFieldNamePolicy = TFieldNamePolicy.fpLowerCase);
|
||||
procedure LoadJSONArrayFromJSONObjectProperty(const AJSONObjectString: string; const aPropertyName: String;
|
||||
const AFieldNamePolicy: TFieldNamePolicy = TFieldNamePolicy.fpLowerCase);
|
||||
procedure AppendFromJSONArrayString(AJSONArrayString: string); overload;
|
||||
procedure AppendFromJSONArrayString(AJSONArrayString: string; AIgnoredFields: TArray<string>;
|
||||
AFieldNamePolicy: TFieldNamePolicy = TFieldNamePolicy.fpLowerCase); overload;
|
||||
@ -152,14 +153,15 @@ begin
|
||||
|
||||
end;
|
||||
|
||||
procedure TDataSetHelper.LoadJSONArrayFromJSONObjectProperty(const AJSONObjectString: string; const aPropertyName: String; const aFieldNamePolicy: TFieldNamePolicy);
|
||||
procedure TDataSetHelper.LoadJSONArrayFromJSONObjectProperty(const AJSONObjectString: string;
|
||||
const aPropertyName: String; const AFieldNamePolicy: TFieldNamePolicy);
|
||||
var
|
||||
lJson: TJSONObject;
|
||||
begin
|
||||
lJson := TJSONObject.Create;
|
||||
try
|
||||
lJson.FromJSON(AJSONObjectString);
|
||||
LoadFromJSONArray(lJson.A[aPropertyName], aFieldNamePolicy);
|
||||
LoadFromJSONArray(lJson.A[aPropertyName], AFieldNamePolicy);
|
||||
finally
|
||||
lJson.Free;
|
||||
end;
|
||||
@ -364,7 +366,7 @@ class procedure TDataSetUtils.DataSetToObject(ADataSet: TDataSet; AObject: TObje
|
||||
var
|
||||
_type: TRttiType;
|
||||
_fields: TArray<TRttiProperty>;
|
||||
_field: TRttiProperty;
|
||||
lRttiProp: TRttiProperty;
|
||||
_attribute: TCustomAttribute;
|
||||
_dict: TDictionary<string, string>;
|
||||
_keys: TDictionary<string, boolean>;
|
||||
@ -379,32 +381,32 @@ begin
|
||||
_keys := TDictionary<string, boolean>.Create();
|
||||
_type := CTX.GetType(AObject.ClassInfo);
|
||||
_fields := _type.GetProperties;
|
||||
for _field in _fields do
|
||||
for lRttiProp in _fields do
|
||||
begin
|
||||
FoundAttribute := false;
|
||||
FoundTransientAttribute := false;
|
||||
for _attribute in _field.GetAttributes do
|
||||
for _attribute in lRttiProp.GetAttributes do
|
||||
begin
|
||||
if _attribute is MVCColumnAttribute then
|
||||
begin
|
||||
FoundAttribute := true;
|
||||
mf := MVCColumnAttribute(_attribute);
|
||||
_dict.Add(_field.Name, mf.FieldName);
|
||||
_keys.Add(_field.Name, mf.IsPK);
|
||||
_dict.Add(lRttiProp.Name, mf.FieldName);
|
||||
_keys.Add(lRttiProp.Name, mf.IsPK);
|
||||
end
|
||||
else if _attribute is MVCDoNotSerializeAttribute then
|
||||
FoundTransientAttribute := true;
|
||||
end;
|
||||
if ((not FoundAttribute) and (not FoundTransientAttribute)) then
|
||||
begin
|
||||
_dict.Add(_field.Name, _field.Name);
|
||||
_keys.Add(_field.Name, false);
|
||||
_dict.Add(lRttiProp.Name, lRttiProp.Name);
|
||||
_keys.Add(lRttiProp.Name, false);
|
||||
end;
|
||||
end;
|
||||
for _field in _fields do
|
||||
for lRttiProp in _fields do
|
||||
begin
|
||||
|
||||
if not _dict.TryGetValue(_field.Name, field_name) then
|
||||
if not _dict.TryGetValue(lRttiProp.Name, field_name) then
|
||||
Continue;
|
||||
|
||||
LField := ADataSet.FindField(field_name);
|
||||
@ -412,10 +414,10 @@ begin
|
||||
if not Assigned(LField) then
|
||||
Continue;
|
||||
|
||||
case _field.PropertyType.TypeKind of
|
||||
case lRttiProp.PropertyType.TypeKind of
|
||||
tkEnumeration: // tristan
|
||||
begin
|
||||
if _field.PropertyType.Handle = TypeInfo(boolean) then
|
||||
if lRttiProp.PropertyType.Handle = TypeInfo(boolean) then
|
||||
begin
|
||||
case LField.DataType of
|
||||
ftInteger, ftSmallint, ftLargeint:
|
||||
@ -441,10 +443,15 @@ begin
|
||||
Value := LField.AsString;
|
||||
tkUString, tkWChar, tkLString, tkWString:
|
||||
Value := LField.AsWideString;
|
||||
{ TODO -oDanieleT -cGeneral : This doesn0t work with nullable types }
|
||||
// tkRecord:
|
||||
// begin
|
||||
/// / MapDataSetFieldToNullableRTTIField(Value, LField, _field, AObject);
|
||||
// end
|
||||
else
|
||||
Continue;
|
||||
end;
|
||||
_field.SetValue(AObject, Value);
|
||||
lRttiProp.SetValue(AObject, Value);
|
||||
end;
|
||||
_dict.Free;
|
||||
_keys.Free;
|
||||
|
@ -281,6 +281,10 @@ function DateTimeToISOTimeStamp(const ADateTime: TDateTime): string;
|
||||
function DateToISODate(const ADate: TDateTime): string;
|
||||
function TimeToISOTime(const ATime: TTime): string;
|
||||
|
||||
procedure MapDataSetFieldToRTTIField(const AField: TField; const aRTTIField: TRttiField; const AObject: TObject);
|
||||
function MapDataSetFieldToNullableRTTIField(const AValue: TValue; const AField: TField; const aRTTIField: TRttiField;
|
||||
const AObject: TObject): boolean;
|
||||
|
||||
/// <summary>
|
||||
/// Supports ISO8601 in the following formats:
|
||||
/// yyyy-mm-ddThh:nn:ss
|
||||
@ -303,7 +307,7 @@ implementation
|
||||
|
||||
uses
|
||||
MVCFramework.Serializer.JsonDataObjects,
|
||||
MVCFramework.Serializer.Intf;
|
||||
MVCFramework.Serializer.Intf, Data.FmtBcd, MVCFramework.Nullables;
|
||||
|
||||
function NewObjectHolder(const AObject: TObject; const AMetaFiller: TProc<TMVCStringDictionary> = nil;
|
||||
const AOwns: boolean = false): TMVCObjectResponse;
|
||||
@ -795,4 +799,308 @@ begin
|
||||
inherited Create(AObject, Owns, dstSingleRecord);
|
||||
end;
|
||||
|
||||
procedure MapDataSetFieldToRTTIField(const AField: TField; const aRTTIField: TRttiField; const AObject: TObject);
|
||||
var
|
||||
lInternalStream: TStream;
|
||||
lSStream: TStringStream;
|
||||
lValue: TValue;
|
||||
begin
|
||||
lValue := aRTTIField.GetValue(AObject);
|
||||
if lValue.Kind = tkRecord then
|
||||
begin
|
||||
if MapDataSetFieldToNullableRTTIField(lValue, AField, aRTTIField, AObject) then
|
||||
begin
|
||||
Exit;
|
||||
end;
|
||||
end;
|
||||
|
||||
// if we reached this point, the field is not a nullable type...
|
||||
case AField.DataType of
|
||||
ftString, ftWideString:
|
||||
begin
|
||||
aRTTIField.SetValue(AObject, AField.AsString);
|
||||
end;
|
||||
ftLargeint, ftAutoInc:
|
||||
begin
|
||||
aRTTIField.SetValue(AObject, AField.AsLargeInt);
|
||||
end;
|
||||
ftInteger, ftSmallint, ftShortint:
|
||||
begin
|
||||
aRTTIField.SetValue(AObject, AField.AsInteger);
|
||||
end;
|
||||
ftLongWord, ftWord:
|
||||
begin
|
||||
aRTTIField.SetValue(AObject, AField.AsLongWord);
|
||||
end;
|
||||
ftFMTBcd:
|
||||
begin
|
||||
aRTTIField.SetValue(AObject, BCDtoCurrency(AField.AsBCD));
|
||||
end;
|
||||
ftDate:
|
||||
begin
|
||||
aRTTIField.SetValue(AObject, Trunc(AField.AsDateTime));
|
||||
end;
|
||||
ftDateTime:
|
||||
begin
|
||||
aRTTIField.SetValue(AObject, Trunc(AField.AsDateTime));
|
||||
end;
|
||||
ftTimeStamp:
|
||||
begin
|
||||
aRTTIField.SetValue(AObject, AField.AsDateTime);
|
||||
end;
|
||||
ftBoolean:
|
||||
begin
|
||||
aRTTIField.SetValue(AObject, AField.AsBoolean);
|
||||
end;
|
||||
ftMemo, ftWideMemo:
|
||||
begin
|
||||
if aRTTIField.FieldType.TypeKind in [tkString, tkUString { , tkWideString } ] then
|
||||
begin
|
||||
// In case you want to map a "TEXT" blob into a Delphi String
|
||||
lSStream := TStringStream.Create('', TEncoding.Unicode);
|
||||
try
|
||||
TBlobField(AField).SaveToStream(lSStream);
|
||||
aRTTIField.SetValue(AObject, lSStream.DataString);
|
||||
finally
|
||||
lSStream.Free;
|
||||
end;
|
||||
end
|
||||
else
|
||||
begin
|
||||
// In case you want to map a binary blob into a Delphi Stream
|
||||
lInternalStream := aRTTIField.GetValue(AObject).AsObject as TStream;
|
||||
if lInternalStream = nil then
|
||||
begin
|
||||
raise EMVCException.CreateFmt('Property target for %s field is nil', [AField.Name]);
|
||||
end;
|
||||
lInternalStream.Position := 0;
|
||||
TBlobField(AField).SaveToStream(lInternalStream);
|
||||
lInternalStream.Position := 0;
|
||||
end;
|
||||
end;
|
||||
ftBCD:
|
||||
begin
|
||||
aRTTIField.SetValue(AObject, BCDtoCurrency(AField.AsBCD));
|
||||
end;
|
||||
ftFloat:
|
||||
begin
|
||||
aRTTIField.SetValue(AObject, AField.AsFloat);
|
||||
end;
|
||||
ftBlob:
|
||||
begin
|
||||
lInternalStream := aRTTIField.GetValue(AObject).AsObject as TStream;
|
||||
if AField.IsNull then
|
||||
begin
|
||||
lInternalStream.Free;
|
||||
aRTTIField.SetValue(AObject, nil);
|
||||
Exit;
|
||||
end;
|
||||
if lInternalStream = nil then
|
||||
begin
|
||||
lInternalStream := TMemoryStream.Create;
|
||||
aRTTIField.SetValue(AObject, lInternalStream);
|
||||
// raise EMVCActiveRecord.CreateFmt('Property target for %s field is nil', [aFieldName]);
|
||||
end;
|
||||
lInternalStream.Position := 0;
|
||||
TBlobField(AField).SaveToStream(lInternalStream);
|
||||
lInternalStream.Position := 0;
|
||||
end;
|
||||
{$IF Defined(SeattleOrBetter)}
|
||||
ftGuid:
|
||||
begin
|
||||
aRTTIField.SetValue(AObject, TValue.From<TGUID>(AField.AsGuid));
|
||||
end;
|
||||
{$ENDIF}
|
||||
else
|
||||
raise EMVCException.CreateFmt('Unsupported FieldType (%d) for field %s', [Ord(AField.DataType), AField.Name]);
|
||||
end;
|
||||
end;
|
||||
|
||||
function MapDataSetFieldToNullableRTTIField(const AValue: TValue; const AField: TField; const aRTTIField: TRttiField;
|
||||
const AObject: TObject): boolean;
|
||||
begin
|
||||
Assert(AValue.Kind = tkRecord);
|
||||
Result := false;
|
||||
if AValue.IsType(TypeInfo(NullableString)) then
|
||||
begin
|
||||
if AField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(AObject).AsType<NullableString>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(aObject, TValue.From<NullableString>(AField.AsString));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if AValue.IsType(TypeInfo(NullableInt32)) then
|
||||
begin
|
||||
if AField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(aObject).AsType<NullableInt32>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(aObject, TValue.From<NullableInt32>(AField.AsLargeInt));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if AValue.IsType(TypeInfo(NullableUInt32)) then
|
||||
begin
|
||||
if AField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(aObject).AsType<NullableUInt32>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(aObject, TValue.From<NullableUInt32>(AField.AsLargeInt));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if AValue.IsType(TypeInfo(NullableInt64)) then
|
||||
begin
|
||||
if AField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(aObject).AsType<NullableInt64>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(aObject, TValue.From<NullableInt64>(AField.AsLargeInt));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if AValue.IsType(TypeInfo(NullableUInt64)) then
|
||||
begin
|
||||
if AField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(aObject).AsType<NullableUInt64>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(aObject, TValue.From<NullableUInt64>(AField.AsLargeInt));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if AValue.IsType(TypeInfo(NullableInt16)) then
|
||||
begin
|
||||
if AField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(aObject).AsType<NullableInt16>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(aObject, TValue.From<NullableInt16>(AField.AsLargeInt));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if AValue.IsType(TypeInfo(NullableUInt16)) then
|
||||
begin
|
||||
if AField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(aObject).AsType<NullableUInt16>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(aObject, TValue.From<NullableUInt16>(AField.AsInteger));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if AValue.IsType(TypeInfo(NullableTDate)) then
|
||||
begin
|
||||
if AField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(aObject).AsType<NullableTDate>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(aObject, TValue.From<NullableTDate>(AField.AsDateTime));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if AValue.IsType(TypeInfo(NullableTDateTime)) then
|
||||
begin
|
||||
if AField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(aObject).AsType<NullableTDateTime>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(aObject, TValue.From<NullableTDateTime>(AField.AsDateTime));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if AValue.IsType(TypeInfo(NullableTTime)) then
|
||||
begin
|
||||
if AField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(aObject).AsType<NullableTTime>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(aObject, TValue.From<NullableTTime>(AField.AsDateTime));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if AValue.IsType(TypeInfo(NullableBoolean)) then
|
||||
begin
|
||||
if AField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(aObject).AsType<NullableBoolean>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(aObject, TValue.From<NullableBoolean>(AField.AsBoolean));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if AValue.IsType(TypeInfo(NullableDouble)) then
|
||||
begin
|
||||
if AField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(aObject).AsType<NullableDouble>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(aObject, TValue.From<NullableDouble>(AField.AsFloat));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if AValue.IsType(TypeInfo(NullableSingle)) then
|
||||
begin
|
||||
if AField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(aObject).AsType<NullableSingle>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(aObject, TValue.From<NullableSingle>(AField.AsSingle));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if AValue.IsType(TypeInfo(NullableExtended)) then
|
||||
begin
|
||||
if AField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(aObject).AsType<NullableExtended>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(aObject, TValue.From<NullableExtended>(AField.AsExtended));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
else if AValue.IsType(TypeInfo(NullableCurrency)) then
|
||||
begin
|
||||
if AField.IsNull then
|
||||
begin
|
||||
aRTTIField.GetValue(aObject).AsType<NullableCurrency>().Clear;
|
||||
end
|
||||
else
|
||||
begin
|
||||
aRTTIField.SetValue(aObject, TValue.From<NullableCurrency>(AField.AsCurrency));
|
||||
end;
|
||||
Result := True;
|
||||
end
|
||||
end;
|
||||
|
||||
end.
|
||||
|
@ -61,8 +61,8 @@ procedure RegisterOptionalCustomTypesSerializersForJSON(const Serializers
|
||||
implementation
|
||||
|
||||
uses
|
||||
Graphics, {do not specialize VCL or FMX, let use the UnitScope defined in the project}
|
||||
{$IFDEF MSWINDOWS}
|
||||
Vcl.Graphics, {do not specialize VCL or FMX, let use the UnitScope defined in the project}
|
||||
Vcl.Imaging.pngimage, {do not specialize VCL or FMX, le use the UnitScope defined in the project}
|
||||
Vcl.Imaging.jpeg, {do not specialize VCL or FMX, le use the UnitScope defined in the project}
|
||||
{$ENDIF}
|
||||
|
Binary file not shown.
File diff suppressed because it is too large
Load Diff
Binary file not shown.
@ -196,7 +196,7 @@ type
|
||||
[MVCHTTPMethod([httpGET])]
|
||||
procedure TestGetImagePng;
|
||||
|
||||
//Nullables Tests
|
||||
// Nullables Tests
|
||||
[MVCHTTPMethod([httpPOST])]
|
||||
[MVCPath('/nullables/pingpong')]
|
||||
procedure TestDeserializeAndSerializeNullables;
|
||||
@ -209,7 +209,6 @@ type
|
||||
[MVCPath('/nullables/getsinglewithnulls')]
|
||||
procedure TestSerializeNullablesWithNulls;
|
||||
|
||||
|
||||
// Response Objects Tests
|
||||
[MVCHTTPMethod([httpPOST])]
|
||||
[MVCPath('/responses/created')]
|
||||
@ -413,7 +412,9 @@ begin
|
||||
lCustomer := Context.Request.BodyAs<TCustomer>();
|
||||
// lCustomer.Logo.SaveToFile('pippo_server_before.bmp');
|
||||
lCustomer.Name := lCustomer.Name + ' changed';
|
||||
{$IFNDEF LINUX}
|
||||
lCustomer.Logo.Canvas.TextOut(10, 10, 'Changed');
|
||||
{$ENDIF}
|
||||
// lCustomer.Logo.SaveToFile('pippo_server_after.bmp');
|
||||
Render(lCustomer, True);
|
||||
end;
|
||||
@ -590,12 +591,12 @@ end;
|
||||
|
||||
procedure TTestServerController.TestResponseAccepted;
|
||||
begin
|
||||
ResponseAccepted('http://pippo.it/1234','1234','thisisthereason');
|
||||
ResponseAccepted('http://pippo.it/1234', '1234', 'thisisthereason');
|
||||
end;
|
||||
|
||||
procedure TTestServerController.TestResponseCreated;
|
||||
begin
|
||||
ResponseCreated('thisisthelocation','thisisthereason');
|
||||
ResponseCreated('thisisthelocation', 'thisisthereason');
|
||||
end;
|
||||
|
||||
procedure TTestServerController.TestResponseNoContent;
|
||||
|
Loading…
Reference in New Issue
Block a user