expand WRITE_PROPERTY macro

in case the property is an Any this commit changes behaviour.
(ComponentData, FilterData and ViewData)
ISSET_%Property% is only true if the property value hasValue(),
before it was always true.

Change-Id: I3bea0bde99938911354f619ac092666199aa2016
Reviewed-on: https://gerrit.libreoffice.org/30038
Tested-by: Jenkins <ci@libreoffice.org>
Reviewed-by: Noel Grandin <noel.grandin@collabora.co.uk>
diff --git a/chart2/source/tools/MediaDescriptorHelper.cxx b/chart2/source/tools/MediaDescriptorHelper.cxx
index 50a9b5c3..b964efa 100644
--- a/chart2/source/tools/MediaDescriptorHelper.cxx
+++ b/chart2/source/tools/MediaDescriptorHelper.cxx
@@ -24,31 +24,6 @@ using namespace ::com::sun::star;
namespace apphelper
{

const short FLAG_DEPRECATED =1;
const short FLAG_MODEL      =2;

#define WRITE_PROPERTY( MediaName, nFlags )             \
if(rProp.Name == #MediaName) \
{                                                       \
    if( rProp.Value >>= MediaName )                     \
        ISSET_##MediaName = true;                       \
    if((nFlags & FLAG_DEPRECATED) != 0)                 \
    {                                                   \
        m_aDeprecatedProperties[nDeprecatedCount]=rProp;\
        nDeprecatedCount++;                             \
    }                                                   \
    else                                                \
    {                                                   \
        m_aRegularProperties[nRegularCount]=rProp;      \
        nRegularCount++;                                \
        if((nFlags & FLAG_MODEL) != 0)                  \
        {                                               \
            m_aModelProperties[nModelCount]=rProp;      \
            nModelCount++;                              \
        }                                               \
    }                                                   \
}

MediaDescriptorHelper::MediaDescriptorHelper( const uno::Sequence<
                        beans::PropertyValue > & rMediaDescriptor )
    : m_aRegularProperties(rMediaDescriptor.getLength())
@@ -57,57 +32,241 @@ MediaDescriptorHelper::MediaDescriptorHelper( const uno::Sequence<
    , m_aModelProperties(rMediaDescriptor.getLength())
{
    impl_init();

    sal_Int32 nRegularCount = 0;
    sal_Int32 nDeprecatedCount = 0;
    sal_Int32 nAdditionalCount = 0;
    sal_Int32 nModelCount = 0;

    auto addRegularProp = [this, &nRegularCount](const beans::PropertyValue& rRegularProp)
    {
        m_aRegularProperties[nRegularCount] = rRegularProp;
        ++nRegularCount;
    };
    auto addModelProp = [this, &nModelCount, &addRegularProp](const beans::PropertyValue& rModelProp)
    {
        addRegularProp(rModelProp);
        m_aModelProperties[nModelCount] = rModelProp;
        ++nModelCount;
    };
    auto addDepreciatedProp = [this, &nDeprecatedCount](const beans::PropertyValue& rDeprecatedProp)
    {
        m_aDeprecatedProperties[nDeprecatedCount] = rDeprecatedProp;
        ++nDeprecatedCount;
    };

    //read given rMediaDescriptor and store in internal structures:
    for( sal_Int32 i= rMediaDescriptor.getLength();i--;)
    {
        const beans::PropertyValue& rProp = rMediaDescriptor[i];
        WRITE_PROPERTY( AsTemplate, FLAG_MODEL )
        else WRITE_PROPERTY( Author, FLAG_MODEL )
        else WRITE_PROPERTY( CharacterSet, FLAG_MODEL )
        else WRITE_PROPERTY( Comment, FLAG_MODEL )
        else WRITE_PROPERTY( ComponentData, FLAG_MODEL )
        else WRITE_PROPERTY( FileName, FLAG_DEPRECATED )
        else WRITE_PROPERTY( FilterData, FLAG_MODEL )
        else WRITE_PROPERTY( FilterName, FLAG_MODEL )
        else WRITE_PROPERTY( FilterFlags, FLAG_DEPRECATED)
        else WRITE_PROPERTY( FilterOptions, FLAG_MODEL )
        else WRITE_PROPERTY( FrameName, FLAG_MODEL )
        else WRITE_PROPERTY( Hidden, FLAG_MODEL )
        else WRITE_PROPERTY( HierarchicalDocumentName, FLAG_MODEL )
        else WRITE_PROPERTY( OutputStream, 0 )
        else WRITE_PROPERTY( InputStream, 0 )
        else WRITE_PROPERTY( InteractionHandler, 0 )
        else WRITE_PROPERTY( JumpMark, 0 )
        else WRITE_PROPERTY( MediaType, FLAG_MODEL )
        else WRITE_PROPERTY( OpenFlags, FLAG_DEPRECATED )
        else WRITE_PROPERTY( OpenNewView, 0 )
        else WRITE_PROPERTY( Overwrite, FLAG_MODEL )
        else WRITE_PROPERTY( Password, FLAG_MODEL )
        else WRITE_PROPERTY( PosSize, 0 )
        else WRITE_PROPERTY( PostData, 0 )
        else WRITE_PROPERTY( PostString, FLAG_DEPRECATED )
        else WRITE_PROPERTY( Preview, FLAG_MODEL )
        else WRITE_PROPERTY( ReadOnly, 0 )
        else WRITE_PROPERTY( Referer, FLAG_MODEL )
        else WRITE_PROPERTY( SetEmbedded, 0 )
        else WRITE_PROPERTY( Silent, 0 )
        else WRITE_PROPERTY( StatusIndicator, 0 )
        else WRITE_PROPERTY( Storage, FLAG_MODEL )
        else WRITE_PROPERTY( Stream, FLAG_MODEL )
        else WRITE_PROPERTY( TemplateName, FLAG_DEPRECATED )
        else WRITE_PROPERTY( TemplateRegionName, FLAG_DEPRECATED )
        else WRITE_PROPERTY( Unpacked, FLAG_MODEL )
        else WRITE_PROPERTY( URL, FLAG_MODEL )
        else WRITE_PROPERTY( Version, FLAG_MODEL )
        else WRITE_PROPERTY( ViewData, FLAG_MODEL )
        else WRITE_PROPERTY( ViewId, FLAG_MODEL )
        else WRITE_PROPERTY( WinExtent, FLAG_DEPRECATED )

        if (rProp.Name == "AsTemplate")
        {
            ISSET_AsTemplate = rProp.Value >>= AsTemplate;
            addModelProp(rProp);
        }
        else if (rProp.Name == "Author")
        {
            ISSET_Author = rProp.Value >>= Author;
            addModelProp(rProp);
        }
        else if (rProp.Name == "CharacterSet")
        {
            ISSET_CharacterSet = rProp.Value >>= CharacterSet;
            addModelProp(rProp);
        }
        else if (rProp.Name == "Comment")
        {
            ISSET_Comment = rProp.Value >>= Comment;
            addModelProp(rProp);
        }
        else if (rProp.Name == "ComponentData")
        {
            ComponentData = rProp.Value;
            ISSET_ComponentData = ComponentData.hasValue();
            addModelProp(rProp);
        }
        else if (rProp.Name == "FileName")
        {
            ISSET_FileName = rProp.Value >>= FileName;
            addDepreciatedProp(rProp);
        }
        else if (rProp.Name == "FilterData")
        {
            FilterData = rProp.Value;
            ISSET_FilterData = FilterData.hasValue();
            addModelProp(rProp);
        }
        else if (rProp.Name == "FilterName")
        {
            ISSET_FilterName = rProp.Value >>= FilterName;
            addModelProp(rProp);
        }
        else if (rProp.Name == "FilterFlags")
        {
            ISSET_FilterFlags = rProp.Value >>= FilterFlags;
            addDepreciatedProp(rProp);
        }
        else if (rProp.Name == "FilterOptions")
        {
            ISSET_FilterOptions = rProp.Value >>= FilterOptions;
            addModelProp(rProp);
        }
        else if (rProp.Name == "FrameName")
        {
            ISSET_FrameName = rProp.Value >>= FrameName;
            addModelProp(rProp);
        }
        else if (rProp.Name == "Hidden")
        {
            ISSET_Hidden = rProp.Value >>= Hidden;
            addModelProp(rProp);
        }
        else if (rProp.Name == "HierarchicalDocumentName")
        {
            ISSET_HierarchicalDocumentName = rProp.Value >>= HierarchicalDocumentName;
            addModelProp(rProp);
        }
        else if (rProp.Name == "OutputStream")
        {
            ISSET_OutputStream = rProp.Value >>= OutputStream;
            addRegularProp(rProp);
        }
        else if (rProp.Name == "InputStream")
        {
            ISSET_InputStream = rProp.Value >>= InputStream;
            addRegularProp(rProp);
        }
        else if (rProp.Name == "InteractionHandler")
        {
            ISSET_InteractionHandler = rProp.Value >>= InteractionHandler;
            addRegularProp(rProp);
        }
        else if (rProp.Name == "JumpMark")
        {
            ISSET_JumpMark = rProp.Value >>= JumpMark;
            addRegularProp(rProp);
        }
        else if (rProp.Name == "MediaType")
        {
            ISSET_MediaType = rProp.Value >>= MediaType;
            addModelProp(rProp);
        }
        else if (rProp.Name == "OpenFlags")
        {
            ISSET_OpenFlags = rProp.Value >>= OpenFlags;
            addDepreciatedProp(rProp);
        }
        else if (rProp.Name == "OpenNewView")
        {
            ISSET_OpenNewView = rProp.Value >>= OpenNewView;
            addRegularProp(rProp);
        }
        else if (rProp.Name == "Overwrite")
        {
            ISSET_Overwrite = rProp.Value >>= Overwrite;
            addModelProp(rProp);
        }
        else if (rProp.Name == "Password")
        {
            ISSET_Password = rProp.Value >>= Password;
            addModelProp(rProp);
        }
        else if (rProp.Name == "PosSize")
        {
            ISSET_PosSize = rProp.Value >>= PosSize;
            addRegularProp(rProp);
        }
        else if (rProp.Name == "PostData")
        {
            ISSET_PostData = rProp.Value >>= PostData;
            addRegularProp(rProp);
        }
        else if (rProp.Name == "PostString")
        {
            ISSET_PostString = rProp.Value >>= PostString;
            addDepreciatedProp(rProp);
        }
        else if (rProp.Name == "Preview")
        {
            ISSET_Preview = rProp.Value >>= Preview;
            addModelProp(rProp);
        }
        else if (rProp.Name == "ReadOnly")
        {
            ISSET_ReadOnly = rProp.Value >>= ReadOnly;
            addRegularProp(rProp);
        }
        else if (rProp.Name == "Referer")
        {
            ISSET_Referer = rProp.Value >>= Referer;
            addModelProp(rProp);
        }
        else if (rProp.Name == "SetEmbedded")
        {
            ISSET_SetEmbedded = rProp.Value >>= SetEmbedded;
            addRegularProp(rProp);
        }
        else if (rProp.Name == "Silent")
        {
            ISSET_Silent = rProp.Value >>= Silent;
            addRegularProp(rProp);
        }
        else if (rProp.Name == "StatusIndicator")
        {
            ISSET_StatusIndicator = rProp.Value >>= StatusIndicator;
            addRegularProp(rProp);
        }
        else if (rProp.Name == "Storage")
        {
            ISSET_Storage = rProp.Value >>= Storage;
            addModelProp(rProp);
        }
        else if (rProp.Name == "Stream")
        {
            ISSET_Stream = rProp.Value >>= Stream;
            addModelProp(rProp);
        }
        else if (rProp.Name == "TemplateName")
        {
            ISSET_TemplateName = rProp.Value >>= TemplateName;
            addDepreciatedProp(rProp);
        }
        else if (rProp.Name == "TemplateRegionName")
        {
            ISSET_TemplateRegionName = rProp.Value >>= TemplateRegionName;
            addDepreciatedProp(rProp);
        }
        else if (rProp.Name == "Unpacked")
        {
            ISSET_Unpacked = rProp.Value >>= Unpacked;
            addModelProp(rProp);
        }
        else if (rProp.Name == "URL")
        {
            ISSET_URL = rProp.Value >>= URL;
            addModelProp(rProp);
        }
        else if (rProp.Name == "Version")
        {
            ISSET_Version = rProp.Value >>= Version;
            addModelProp(rProp);
        }
        else if (rProp.Name == "ViewData")
        {
            ViewData = rProp.Value;
            ISSET_ViewData = ViewData.hasValue();
            addModelProp(rProp);
        }
        else if (rProp.Name == "ViewId")
        {
            ISSET_ViewId = rProp.Value >>= ViewId;
            addModelProp(rProp);
        }
        else if (rProp.Name == "WinExtent")
        {
            ISSET_WinExtent = rProp.Value >>= WinExtent;
            addDepreciatedProp(rProp);
        }
        else
        {
            m_aAdditionalProperties[nAdditionalCount]=rProp;