[Libreoffice-commits] core.git: include/formula sc/source sc/uiconfig solenv/sanitizers

Caolán McNamara (via logerrit) logerrit at kemper.freedesktop.org
Fri Apr 12 10:46:20 UTC 2019


 include/formula/funcutl.hxx              |   10 
 sc/source/ui/inc/areasdlg.hxx            |   64 +++---
 sc/source/ui/inc/reffact.hxx             |    2 
 sc/source/ui/pagedlg/areasdlg.cxx        |  319 ++++++++++++++-----------------
 sc/source/ui/view/reffact.cxx            |    4 
 sc/source/ui/view/tabvwshc.cxx           |    9 
 sc/uiconfig/scalc/ui/printareasdialog.ui |   23 +-
 solenv/sanitizers/ui/modules/scalc.suppr |    9 
 8 files changed, 219 insertions(+), 221 deletions(-)

New commits:
commit 0b022f7e1a0312ab4db762a198714675cdf65ca8
Author:     Caolán McNamara <caolanm at redhat.com>
AuthorDate: Thu Apr 11 14:52:50 2019 +0100
Commit:     Caolán McNamara <caolanm at redhat.com>
CommitDate: Fri Apr 12 12:45:38 2019 +0200

    weld ScPrintAreasDlg
    
    Change-Id: I1e1d31551b623453a1bade9c932ef1c9e1060f35
    Reviewed-on: https://gerrit.libreoffice.org/70600
    Tested-by: Jenkins
    Reviewed-by: Caolán McNamara <caolanm at redhat.com>
    Tested-by: Caolán McNamara <caolanm at redhat.com>

diff --git a/include/formula/funcutl.hxx b/include/formula/funcutl.hxx
index d2aec01bf90a..d7734d8fd68d 100644
--- a/include/formula/funcutl.hxx
+++ b/include/formula/funcutl.hxx
@@ -159,6 +159,16 @@ public:
         return pLabelWidget;
     }
 
+    void SaveValue()
+    {
+        xEntry->save_value();
+    }
+
+    bool IsValueChangedFromSaved() const
+    {
+        return xEntry->get_value_changed_from_saved();
+    }
+
     void SetGetFocusHdl(const Link<WeldRefEdit&,void>& rLink) { maGetFocusHdl = rLink; }
     void SetLoseFocusHdl(const Link<WeldRefEdit&,void>& rLink) { maLoseFocusHdl = rLink; }
     void SetModifyHdl(const Link<WeldRefEdit&,void>& rLink) { maModifyHdl = rLink; }
diff --git a/sc/source/ui/inc/areasdlg.hxx b/sc/source/ui/inc/areasdlg.hxx
index 098eed033468..694e0447d78a 100644
--- a/sc/source/ui/inc/areasdlg.hxx
+++ b/sc/source/ui/inc/areasdlg.hxx
@@ -28,12 +28,11 @@ class ScDocument;
 class ScViewData;
 class SfxStringItem;
 
-class ScPrintAreasDlg : public ScAnyRefDlg
+class ScPrintAreasDlg : public ScAnyRefDlgController
 {
 public:
-                    ScPrintAreasDlg( SfxBindings* pB, SfxChildWindow* pCW, vcl::Window* pParent );
-                    virtual ~ScPrintAreasDlg() override;
-    virtual void    dispose() override;
+    ScPrintAreasDlg(SfxBindings* pB, SfxChildWindow* pCW, weld::Window* pParent);
+    virtual ~ScPrintAreasDlg() override;
 
     virtual void    SetReference( const ScRange& rRef, ScDocument* pDoc ) override;
     virtual void    AddRefEntry() override;
@@ -41,41 +40,52 @@ public:
     virtual bool    IsTableLocked() const override;
 
     virtual void    SetActive() override;
-    virtual void    Deactivate() override;
-    virtual bool    Close() override;
+    virtual void    Close() override;
 
 private:
-    VclPtr<ListBox>                 pLbPrintArea;
-    VclPtr<formula::RefEdit>        pEdPrintArea;
-    VclPtr<formula::RefButton>      pRbPrintArea;
-
-    VclPtr<ListBox>                 pLbRepeatRow;
-    VclPtr<formula::RefEdit>        pEdRepeatRow;
-    VclPtr<formula::RefButton>      pRbRepeatRow;
-
-    VclPtr<ListBox>                 pLbRepeatCol;
-    VclPtr<formula::RefEdit>        pEdRepeatCol;
-    VclPtr<formula::RefButton>      pRbRepeatCol;
-
-    VclPtr<OKButton>        pBtnOk;
-    VclPtr<CancelButton>    pBtnCancel;
-
     bool            bDlgLostFocus;
-    VclPtr<formula::RefEdit>       pRefInputEdit;
     ScDocument*     pDoc;
     ScViewData*     pViewData;
     SCTAB           nCurTab;
 
+    formula::WeldRefEdit* m_pRefInputEdit;
+
+    std::unique_ptr<weld::ComboBox> m_xLbPrintArea;
+    std::unique_ptr<formula::WeldRefEdit> m_xEdPrintArea;
+    std::unique_ptr<formula::WeldRefButton> m_xRbPrintArea;
+
+    std::unique_ptr<weld::ComboBox> m_xLbRepeatRow;
+    std::unique_ptr<formula::WeldRefEdit> m_xEdRepeatRow;
+    std::unique_ptr<formula::WeldRefButton> m_xRbRepeatRow;
+
+    std::unique_ptr<weld::ComboBox> m_xLbRepeatCol;
+    std::unique_ptr<formula::WeldRefEdit> m_xEdRepeatCol;
+    std::unique_ptr<formula::WeldRefButton> m_xRbRepeatCol;
+
+    std::unique_ptr<weld::Button> m_xBtnOk;
+    std::unique_ptr<weld::Button> m_xBtnCancel;
+
+    std::unique_ptr<weld::Frame> m_xPrintFrame;
+    std::unique_ptr<weld::Frame> m_xRowFrame;
+    std::unique_ptr<weld::Frame> m_xColFrame;
+
+    std::unique_ptr<weld::Label> m_xPrintFrameFT;
+    std::unique_ptr<weld::Label> m_xRowFrameFT;
+    std::unique_ptr<weld::Label> m_xColFrameFT;
+
     void Impl_Reset();
     bool Impl_CheckRefStrings();
     void Impl_FillLists();
-    bool Impl_GetItem( const Edit* pEd, SfxStringItem& rItem );
+    bool Impl_GetItem( const formula::WeldRefEdit* pEd, SfxStringItem& rItem );
 
     // Handler:
-    DECL_LINK( Impl_SelectHdl, ListBox&, void );
-    DECL_LINK( Impl_ModifyHdl, Edit&, void  );
-    DECL_LINK( Impl_BtnHdl,    Button*, void );
-    DECL_LINK( Impl_GetFocusHdl, Control&, void );
+    DECL_LINK( Impl_SelectHdl, weld::ComboBox&, void );
+    DECL_LINK( Impl_ModifyHdl, formula::WeldRefEdit&, void  );
+    DECL_LINK( Impl_BtnHdl,    weld::Button&, void );
+    DECL_LINK( Impl_GetEditFocusHdl, formula::WeldRefEdit&, void );
+    DECL_LINK( Impl_LoseEditFocusHdl, formula::WeldRefEdit&, void );
+    DECL_LINK( Impl_LoseButtonFocusHdl, formula::WeldRefButton&, void );
+    DECL_LINK( Impl_GetFocusHdl, weld::Widget&, void );
 };
 
 #endif
diff --git a/sc/source/ui/inc/reffact.hxx b/sc/source/ui/inc/reffact.hxx
index 79a873f31115..444abd3b1362 100644
--- a/sc/source/ui/inc/reffact.hxx
+++ b/sc/source/ui/inc/reffact.hxx
@@ -55,7 +55,7 @@ DECL_WRAPPER_WITHID(ScFilterDlgWrapper)
 DECL_WRAPPER_WITHID(ScSpecialFilterDlgWrapper)
 DECL_WRAPPER_WITHID_CONTROLLER(ScDbNameDlgWrapper)
 DECL_WRAPPER_WITHID(ScConsolidateDlgWrapper)
-DECL_WRAPPER_WITHID(ScPrintAreasDlgWrapper)
+DECL_WRAPPER_WITHID_CONTROLLER(ScPrintAreasDlgWrapper)
 DECL_WRAPPER_WITHID(ScColRowNameRangesDlgWrapper)
 DECL_WRAPPER_WITHID(ScFormulaDlgWrapper)
 DECL_WRAPPER_WITHID(ScHighlightChgDlgWrapper)
diff --git a/sc/source/ui/pagedlg/areasdlg.cxx b/sc/source/ui/pagedlg/areasdlg.cxx
index 22c6bdfc7d14..c2da98481321 100644
--- a/sc/source/ui/pagedlg/areasdlg.cxx
+++ b/sc/source/ui/pagedlg/areasdlg.cxx
@@ -95,34 +95,39 @@ static void printAddressFlags(ScRefFlags nFlag)
 
 //  class ScPrintAreasDlg
 
-ScPrintAreasDlg::ScPrintAreasDlg( SfxBindings* pB, SfxChildWindow* pCW, vcl::Window* pParent )
-    : ScAnyRefDlg(pB, pCW, pParent, "PrintAreasDialog", "modules/scalc/ui/printareasdialog.ui")
+ScPrintAreasDlg::ScPrintAreasDlg(SfxBindings* pB, SfxChildWindow* pCW, weld::Window* pParent)
+    : ScAnyRefDlgController(pB, pCW, pParent, "modules/scalc/ui/printareasdialog.ui", "PrintAreasDialog")
     , bDlgLostFocus(false)
     , pDoc(nullptr)
     , pViewData(nullptr)
     , nCurTab(0)
+    , m_xLbPrintArea(m_xBuilder->weld_combo_box("lbprintarea"))
+    , m_xEdPrintArea(new formula::WeldRefEdit(m_xBuilder->weld_entry("edprintarea")))
+    , m_xRbPrintArea(new formula::WeldRefButton(m_xBuilder->weld_button("rbprintarea")))
+    , m_xLbRepeatRow(m_xBuilder->weld_combo_box("lbrepeatrow"))
+    , m_xEdRepeatRow(new formula::WeldRefEdit(m_xBuilder->weld_entry("edrepeatrow")))
+    , m_xRbRepeatRow(new formula::WeldRefButton(m_xBuilder->weld_button("rbrepeatrow")))
+    , m_xLbRepeatCol(m_xBuilder->weld_combo_box("lbrepeatcol"))
+    , m_xEdRepeatCol(new formula::WeldRefEdit(m_xBuilder->weld_entry("edrepeatcol")))
+    , m_xRbRepeatCol(new formula::WeldRefButton(m_xBuilder->weld_button("rbrepeatcol")))
+    , m_xBtnOk(m_xBuilder->weld_button("ok"))
+    , m_xBtnCancel(m_xBuilder->weld_button("cancel"))
+    , m_xPrintFrame(m_xBuilder->weld_frame("printframe"))
+    , m_xRowFrame(m_xBuilder->weld_frame("rowframe"))
+    , m_xColFrame(m_xBuilder->weld_frame("colframe"))
+    , m_xPrintFrameFT(m_xPrintFrame->weld_label_widget())
+    , m_xRowFrameFT(m_xRowFrame->weld_label_widget())
+    , m_xColFrameFT(m_xColFrame->weld_label_widget())
 {
-    get(pLbPrintArea,"lbprintarea");
-    get(pEdPrintArea,"edprintarea");
-    pEdPrintArea->SetReferences(this, get<VclFrame>("printframe")->get_label_widget());
-    pRefInputEdit = pEdPrintArea;
-    get(pRbPrintArea,"rbprintarea");
-    pRbPrintArea->SetReferences(this, pEdPrintArea);
-
-    get(pLbRepeatRow,"lbrepeatrow");
-    get(pEdRepeatRow,"edrepeatrow");
-    pEdRepeatRow->SetReferences(this, get<VclFrame>("rowframe")->get_label_widget());
-    get(pRbRepeatRow,"rbrepeatrow");
-    pRbRepeatRow->SetReferences(this, pEdRepeatRow);
-
-    get(pLbRepeatCol,"lbrepeatcol");
-    get(pEdRepeatCol,"edrepeatcol");
-    pEdRepeatCol->SetReferences(this, get<VclFrame>("colframe")->get_label_widget());
-    get(pRbRepeatCol,"rbrepeatcol");
-    pRbRepeatCol->SetReferences(this, pEdRepeatCol);
-
-    get(pBtnOk,"ok");
-    get(pBtnCancel,"cancel");
+    m_xEdPrintArea->SetReferences(this, m_xPrintFrameFT.get());
+    m_pRefInputEdit = m_xEdPrintArea.get();
+    m_xRbPrintArea->SetReferences(this, m_xEdPrintArea.get());
+
+    m_xEdRepeatRow->SetReferences(this, m_xRowFrameFT.get());
+    m_xRbRepeatRow->SetReferences(this, m_xEdRepeatRow.get());
+
+    m_xEdRepeatCol->SetReferences(this, m_xColFrameFT.get());
+    m_xRbRepeatCol->SetReferences(this, m_xEdRepeatCol.get());
 
     ScTabViewShell* pScViewSh = dynamic_cast<ScTabViewShell*>( SfxViewShell::Current()  );
     ScDocShell* pScDocSh = dynamic_cast<ScDocShell*>(SfxObjectShell::Current());
@@ -144,38 +149,11 @@ ScPrintAreasDlg::ScPrintAreasDlg( SfxBindings* pB, SfxChildWindow* pCW, vcl::Win
 
 ScPrintAreasDlg::~ScPrintAreasDlg()
 {
-    disposeOnce();
-}
-
-void ScPrintAreasDlg::dispose()
-{
-    // clean extra data of ListBox entries
-    ListBox* aLb[3] = { pLbPrintArea, pLbRepeatRow, pLbRepeatCol };
-
-    for (ListBox* pBox : aLb)
-    {
-        const sal_Int32 nCount = pBox->GetEntryCount();
-        for ( sal_Int32 j=0; j<nCount; j++ )
-            delete static_cast<OUString*>(pBox->GetEntryData(j));
-    }
-    pLbPrintArea.clear();
-    pEdPrintArea.clear();
-    pRbPrintArea.clear();
-    pLbRepeatRow.clear();
-    pEdRepeatRow.clear();
-    pRbRepeatRow.clear();
-    pLbRepeatCol.clear();
-    pEdRepeatCol.clear();
-    pRbRepeatCol.clear();
-    pBtnOk.clear();
-    pBtnCancel.clear();
-    pRefInputEdit.clear();
-    ScAnyRefDlg::dispose();
 }
 
-bool ScPrintAreasDlg::Close()
+void ScPrintAreasDlg::Close()
 {
-    return DoClose( ScPrintAreasDlgWrapper::GetChildWindowId() );
+    DoClose( ScPrintAreasDlgWrapper::GetChildWindowId() );
 }
 
 bool ScPrintAreasDlg::IsTableLocked() const
@@ -188,53 +166,58 @@ bool ScPrintAreasDlg::IsTableLocked() const
 
 void ScPrintAreasDlg::SetReference( const ScRange& rRef, ScDocument* /* pDoc */ )
 {
-    if ( pRefInputEdit )
+    if ( m_pRefInputEdit )
     {
         if ( rRef.aStart != rRef.aEnd )
-            RefInputStart( pRefInputEdit );
+            RefInputStart( m_pRefInputEdit );
 
         OUString  aStr;
         const formula::FormulaGrammar::AddressConvention eConv = pDoc->GetAddressConvention();
 
-        if ( pEdPrintArea == pRefInputEdit )
+        if (m_xEdPrintArea.get() == m_pRefInputEdit)
         {
             aStr = rRef.Format(ScRefFlags::RANGE_ABS, pDoc, eConv);
-            OUString aVal = pEdPrintArea->GetText();
-            Selection aSel = pEdPrintArea->GetSelection();
+            OUString aVal = m_xEdPrintArea->GetText();
+            Selection aSel = m_xEdPrintArea->GetSelection();
             aSel.Justify();
             aVal = aVal.replaceAt( aSel.Min(), aSel.Len(), aStr );
             Selection aNewSel( aSel.Min(), aSel.Min()+aStr.getLength() );
-            pEdPrintArea->SetRefString( aVal );
-            pEdPrintArea->SetSelection( aNewSel );
+            m_xEdPrintArea->SetRefString( aVal );
+            m_xEdPrintArea->SetSelection( aNewSel );
         }
         else
         {
-            bool bRow = ( pEdRepeatRow == pRefInputEdit );
+            bool bRow = ( m_xEdRepeatRow.get() == m_pRefInputEdit );
             lcl_GetRepeatRangeString(&rRef, pDoc, bRow, aStr);
-            pRefInputEdit->SetRefString( aStr );
+            m_pRefInputEdit->SetRefString( aStr );
         }
-        Impl_ModifyHdl( *pRefInputEdit );
+        Impl_ModifyHdl( *m_pRefInputEdit );
     }
 }
 
 void ScPrintAreasDlg::AddRefEntry()
 {
-    if ( pRefInputEdit == pEdPrintArea )
+    if (m_pRefInputEdit == m_xEdPrintArea.get())
     {
         const sal_Unicode sep = ScCompiler::GetNativeSymbolChar(ocSep);
-        OUString aVal = pEdPrintArea->GetText() + OUStringLiteral1(sep);
-        pEdPrintArea->SetText(aVal);
+        OUString aVal = m_xEdPrintArea->GetText() + OUStringLiteral1(sep);
+        m_xEdPrintArea->SetText(aVal);
 
         sal_Int32 nLen = aVal.getLength();
-        pEdPrintArea->SetSelection( Selection( nLen, nLen ) );
+        m_xEdPrintArea->SetSelection( Selection( nLen, nLen ) );
 
-        Impl_ModifyHdl( *pEdPrintArea );
+        Impl_ModifyHdl( *m_xEdPrintArea );
     }
 }
 
-void ScPrintAreasDlg::Deactivate()
+IMPL_LINK_NOARG(ScPrintAreasDlg, Impl_LoseEditFocusHdl, formula::WeldRefEdit&, void)
+{
+    bDlgLostFocus = !m_xDialog->has_toplevel_focus();
+}
+
+IMPL_LINK_NOARG(ScPrintAreasDlg, Impl_LoseButtonFocusHdl, formula::WeldRefButton&, void)
 {
-    bDlgLostFocus = true;
+    bDlgLostFocus = !m_xDialog->has_toplevel_focus();
 }
 
 void ScPrintAreasDlg::SetActive()
@@ -243,14 +226,14 @@ void ScPrintAreasDlg::SetActive()
     {
         bDlgLostFocus = false;
 
-        if ( pRefInputEdit )
+        if ( m_pRefInputEdit )
         {
-            pRefInputEdit->GrabFocus();
-            Impl_ModifyHdl( *pRefInputEdit );
+            m_pRefInputEdit->GrabFocus();
+            Impl_ModifyHdl( *m_pRefInputEdit );
         }
     }
     else
-        GrabFocus();
+        m_xDialog->grab_focus();
 
     RefInputDone();
 }
@@ -261,20 +244,26 @@ void ScPrintAreasDlg::Impl_Reset()
     const ScRange*  pRepeatColRange = pDoc->GetRepeatColRange( nCurTab );
     const ScRange*  pRepeatRowRange = pDoc->GetRepeatRowRange( nCurTab );
 
-    pEdPrintArea->SetModifyHdl   ( HDL(Impl_ModifyHdl) );
-    pEdRepeatRow->SetModifyHdl   ( HDL(Impl_ModifyHdl) );
-    pEdRepeatCol->SetModifyHdl   ( HDL(Impl_ModifyHdl) );
-    pEdPrintArea->SetGetFocusHdl( HDL(Impl_GetFocusHdl) );
-    pEdRepeatRow->SetGetFocusHdl( HDL(Impl_GetFocusHdl) );
-    pEdRepeatCol->SetGetFocusHdl( HDL(Impl_GetFocusHdl) );
-    pLbPrintArea->SetGetFocusHdl( HDL(Impl_GetFocusHdl) );
-    pLbRepeatRow->SetGetFocusHdl( HDL(Impl_GetFocusHdl) );
-    pLbRepeatCol->SetGetFocusHdl( HDL(Impl_GetFocusHdl) );
-    pLbPrintArea->SetSelectHdl   ( HDL(Impl_SelectHdl) );
-    pLbRepeatRow->SetSelectHdl   ( HDL(Impl_SelectHdl) );
-    pLbRepeatCol->SetSelectHdl   ( HDL(Impl_SelectHdl) );
-    pBtnOk->      SetClickHdl    ( HDL(Impl_BtnHdl)    );
-    pBtnCancel->  SetClickHdl    ( HDL(Impl_BtnHdl)    );
+    m_xEdPrintArea->SetModifyHdl   ( HDL(Impl_ModifyHdl) );
+    m_xEdRepeatRow->SetModifyHdl   ( HDL(Impl_ModifyHdl) );
+    m_xEdRepeatCol->SetModifyHdl   ( HDL(Impl_ModifyHdl) );
+    m_xEdPrintArea->SetGetFocusHdl( HDL(Impl_GetEditFocusHdl) );
+    m_xEdRepeatRow->SetGetFocusHdl( HDL(Impl_GetEditFocusHdl) );
+    m_xEdRepeatCol->SetGetFocusHdl( HDL(Impl_GetEditFocusHdl) );
+    m_xEdPrintArea->SetLoseFocusHdl( HDL(Impl_LoseEditFocusHdl) );
+    m_xEdRepeatRow->SetLoseFocusHdl( HDL(Impl_LoseEditFocusHdl) );
+    m_xEdRepeatCol->SetLoseFocusHdl( HDL(Impl_LoseEditFocusHdl) );
+    m_xRbPrintArea->SetLoseFocusHdl( HDL(Impl_LoseButtonFocusHdl) );
+    m_xRbRepeatRow->SetLoseFocusHdl( HDL(Impl_LoseButtonFocusHdl) );
+    m_xRbRepeatCol->SetLoseFocusHdl( HDL(Impl_LoseButtonFocusHdl) );
+    m_xLbPrintArea->connect_focus_in( HDL(Impl_GetFocusHdl) );
+    m_xLbRepeatRow->connect_focus_in( HDL(Impl_GetFocusHdl) );
+    m_xLbRepeatCol->connect_focus_in( HDL(Impl_GetFocusHdl) );
+    m_xLbPrintArea->connect_changed( HDL(Impl_SelectHdl) );
+    m_xLbRepeatRow->connect_changed( HDL(Impl_SelectHdl) );
+    m_xLbRepeatCol->connect_changed( HDL(Impl_SelectHdl) );
+    m_xBtnOk->connect_clicked( HDL(Impl_BtnHdl)    );
+    m_xBtnCancel->connect_clicked( HDL(Impl_BtnHdl)    );
 
     Impl_FillLists();
 
@@ -294,39 +283,39 @@ void ScPrintAreasDlg::Impl_Reset()
             aStrRange += pPrintRange->Format(ScRefFlags::RANGE_ABS, pDoc, eConv);
         }
     }
-    pEdPrintArea->SetText( aStrRange );
+    m_xEdPrintArea->SetText( aStrRange );
 
     // repeat row
 
     lcl_GetRepeatRangeString(pRepeatRowRange, pDoc, true, aStrRange);
-    pEdRepeatRow->SetText( aStrRange );
+    m_xEdRepeatRow->SetText( aStrRange );
 
     // repeat column
 
     lcl_GetRepeatRangeString(pRepeatColRange, pDoc, false, aStrRange);
-    pEdRepeatCol->SetText( aStrRange );
+    m_xEdRepeatCol->SetText( aStrRange );
 
-    Impl_ModifyHdl( *pEdPrintArea );
-    Impl_ModifyHdl( *pEdRepeatRow );
-    Impl_ModifyHdl( *pEdRepeatCol );
+    Impl_ModifyHdl( *m_xEdPrintArea );
+    Impl_ModifyHdl( *m_xEdRepeatRow );
+    Impl_ModifyHdl( *m_xEdRepeatCol );
     if( pDoc->IsPrintEntireSheet( nCurTab ) )
-        pLbPrintArea->SelectEntryPos( SC_AREASDLG_PR_ENTIRE );
+        m_xLbPrintArea->set_active(SC_AREASDLG_PR_ENTIRE);
 
-    pEdPrintArea->SaveValue();   // save for FillItemSet():
-    pEdRepeatRow->SaveValue();
-    pEdRepeatCol->SaveValue();
+    m_xEdPrintArea->SaveValue();   // save for FillItemSet():
+    m_xEdRepeatRow->SaveValue();
+    m_xEdRepeatCol->SaveValue();
 }
 
-bool ScPrintAreasDlg::Impl_GetItem( const Edit* pEd, SfxStringItem& rItem )
+bool ScPrintAreasDlg::Impl_GetItem( const formula::WeldRefEdit* pEd, SfxStringItem& rItem )
 {
     OUString  aRangeStr = pEd->GetText();
     bool bDataChanged = pEd->IsValueChangedFromSaved();
 
-    if ( !aRangeStr.isEmpty() && pEdPrintArea != pEd )
+    if ( !aRangeStr.isEmpty() && m_xEdPrintArea.get() != pEd )
     {
         ScRange aRange;
         const formula::FormulaGrammar::AddressConvention eConv = pDoc->GetAddressConvention();
-        lcl_CheckRepeatString(aRangeStr, pDoc, pEdRepeatRow == pEd, &aRange);
+        lcl_CheckRepeatString(aRangeStr, pDoc, m_xEdRepeatRow.get() == pEd, &aRange);
         aRangeStr = aRange.Format(ScRefFlags::RANGE_ABS, pDoc, eConv);
     }
 
@@ -338,9 +327,9 @@ bool ScPrintAreasDlg::Impl_GetItem( const Edit* pEd, SfxStringItem& rItem )
 bool ScPrintAreasDlg::Impl_CheckRefStrings()
 {
     bool        bOk = false;
-    OUString      aStrPrintArea   = pEdPrintArea->GetText();
-    OUString      aStrRepeatRow   = pEdRepeatRow->GetText();
-    OUString      aStrRepeatCol   = pEdRepeatCol->GetText();
+    OUString      aStrPrintArea   = m_xEdPrintArea->GetText();
+    OUString      aStrRepeatRow   = m_xEdRepeatRow->GetText();
+    OUString      aStrRepeatCol   = m_xEdRepeatCol->GetText();
 
     bool bPrintAreaOk = true;
     if ( !aStrPrintArea.isEmpty() )
@@ -382,13 +371,13 @@ bool ScPrintAreasDlg::Impl_CheckRefStrings()
 
     if ( !bOk )
     {
-        Edit* pEd = nullptr;
+        formula::WeldRefEdit* pEd = nullptr;
 
-        if ( !bPrintAreaOk ) pEd = pEdPrintArea;
-        else if ( !bRepeatRowOk ) pEd = pEdRepeatRow;
-        else if ( !bRepeatColOk ) pEd = pEdRepeatCol;
+        if ( !bPrintAreaOk ) pEd = m_xEdPrintArea.get();
+        else if ( !bRepeatRowOk ) pEd = m_xEdRepeatRow.get();
+        else if ( !bRepeatColOk ) pEd = m_xEdRepeatCol.get();
 
-        ERRORBOX(GetFrameWeld(), STR_INVALID_TABREF);
+        ERRORBOX(m_xDialog.get(), STR_INVALID_TABREF);
 
         OSL_ASSERT(pEd);
 
@@ -422,7 +411,7 @@ void ScPrintAreasDlg::Impl_FillLists()
         aList->Format(aStrRange, ScRefFlags::RANGE_ABS, pDoc, eConv);
     }
 
-    pLbPrintArea->SetEntryData( SC_AREASDLG_PR_SELECT, new OUString( aStrRange ) );
+    m_xLbPrintArea->set_id(SC_AREASDLG_PR_SELECT, aStrRange);
 
     // Get ranges and remember in ListBoxen
 
@@ -447,25 +436,19 @@ void ScPrintAreasDlg::Impl_FillLists()
             if (rEntry.second->HasType(ScRangeData::Type::PrintArea))
             {
                 aSymbol = aRange.Format(ScRefFlags::RANGE_ABS, pDoc, eConv);
-                pLbPrintArea->SetEntryData(
-                    pLbPrintArea->InsertEntry(aName),
-                    new OUString(aSymbol) );
+                m_xLbPrintArea->append(aSymbol, aName);
             }
 
             if (rEntry.second->HasType(ScRangeData::Type::RowHeader))
             {
                 lcl_GetRepeatRangeString(&aRange, pDoc, true, aSymbol);
-                pLbRepeatRow->SetEntryData(
-                    pLbRepeatRow->InsertEntry(aName),
-                    new OUString(aSymbol) );
+                m_xLbRepeatRow->append(aSymbol, aName);
             }
 
             if (rEntry.second->HasType(ScRangeData::Type::ColHeader))
             {
                 lcl_GetRepeatRangeString(&aRange, pDoc, false, aSymbol);
-                pLbRepeatCol->SetEntryData(
-                    pLbRepeatCol->InsertEntry(aName),
-                    new OUString(aSymbol));
+                m_xLbRepeatCol->append(aSymbol, aName);
             }
         }
     }
@@ -473,9 +456,9 @@ void ScPrintAreasDlg::Impl_FillLists()
 
 // Handler:
 
-IMPL_LINK( ScPrintAreasDlg, Impl_BtnHdl, Button*, pBtn, void )
+IMPL_LINK(ScPrintAreasDlg, Impl_BtnHdl, weld::Button&, rBtn, void)
 {
-    if ( pBtnOk == pBtn )
+    if (m_xBtnOk.get() == &rBtn)
     {
         if ( Impl_CheckRefStrings() )
         {
@@ -487,23 +470,23 @@ IMPL_LINK( ScPrintAreasDlg, Impl_BtnHdl, Button*, pBtn, void )
             // Printing area changed?
 
             // first try the list box, if "Entire sheet" is selected
-            bool bEntireSheet = (pLbPrintArea->GetSelectedEntryPos() == SC_AREASDLG_PR_ENTIRE);
+            bool bEntireSheet = (m_xLbPrintArea->get_active() == SC_AREASDLG_PR_ENTIRE);
             SfxBoolItem aEntireSheet( FN_PARAM_4, bEntireSheet );
 
             bool bDataChanged = bEntireSheet != pDoc->IsPrintEntireSheet( nCurTab );
             if( !bEntireSheet )
             {
                 // if new list box selection is not "Entire sheet", get the edit field contents
-                bDataChanged |= Impl_GetItem( pEdPrintArea, aPrintArea );
+                bDataChanged |= Impl_GetItem( m_xEdPrintArea.get(), aPrintArea );
             }
 
             // Repeat row changed?
 
-            bDataChanged |= Impl_GetItem( pEdRepeatRow, aRepeatRow );
+            bDataChanged |= Impl_GetItem( m_xEdRepeatRow.get(), aRepeatRow );
 
             // Repeat column changed?
 
-            bDataChanged |= Impl_GetItem( pEdRepeatCol, aRepeatCol );
+            bDataChanged |= Impl_GetItem( m_xEdRepeatCol.get(), aRepeatCol );
 
             if ( bDataChanged )
             {
@@ -514,93 +497,81 @@ IMPL_LINK( ScPrintAreasDlg, Impl_BtnHdl, Button*, pBtn, void )
                       { &aPrintArea, &aRepeatRow, &aRepeatCol, &aEntireSheet });
             }
 
-            Close();
+            response(RET_OK);
         }
     }
-    else if ( pBtnCancel == pBtn )
-        Close();
+    else if (m_xBtnCancel.get() == &rBtn)
+        response(RET_CANCEL);
 }
 
-IMPL_LINK( ScPrintAreasDlg, Impl_GetFocusHdl, Control&, rCtrl, void )
+IMPL_LINK(ScPrintAreasDlg, Impl_GetEditFocusHdl, formula::WeldRefEdit&, rCtrl, void)
 {
-    if ( &rCtrl ==static_cast<Control *>(pEdPrintArea) ||
-         &rCtrl ==static_cast<Control *>(pEdRepeatRow) ||
-         &rCtrl ==static_cast<Control *>(pEdRepeatCol))
-    {
-         pRefInputEdit = static_cast<formula::RefEdit*>(&rCtrl);
-    }
-    else if ( &rCtrl ==static_cast<Control *>(pLbPrintArea))
-    {
-        pRefInputEdit = pEdPrintArea;
-    }
-    else if ( &rCtrl ==static_cast<Control *>(pLbRepeatRow))
-    {
-        pRefInputEdit = pEdRepeatRow;
-    }
-    else if ( &rCtrl ==static_cast<Control *>(pLbRepeatCol))
-    {
-        pRefInputEdit = pEdRepeatCol;
-    }
+    m_pRefInputEdit = &rCtrl;
+}
+
+IMPL_LINK(ScPrintAreasDlg, Impl_GetFocusHdl, weld::Widget&, rCtrl, void)
+{
+    if (&rCtrl == m_xLbPrintArea.get())
+        m_pRefInputEdit = m_xEdPrintArea.get();
+    else if (&rCtrl == m_xLbRepeatRow.get())
+        m_pRefInputEdit = m_xEdRepeatRow.get();
+    else if (&rCtrl == m_xLbRepeatCol.get())
+        m_pRefInputEdit = m_xEdRepeatCol.get();
 }
 
-IMPL_LINK( ScPrintAreasDlg, Impl_SelectHdl, ListBox&, rLb, void )
+IMPL_LINK( ScPrintAreasDlg, Impl_SelectHdl, weld::ComboBox&, rLb, void )
 {
-    ListBox* pLb = &rLb;
-    const sal_Int32 nSelPos = pLb->GetSelectedEntryPos();
-    Edit* pEd = nullptr;
+    const sal_Int32 nSelPos = rLb.get_active();
+    formula::WeldRefEdit* pEd = nullptr;
 
     // list box positions of specific entries, default to "repeat row/column" list boxes
     sal_Int32 nAllSheetPos = SC_AREASDLG_RR_NONE;
-    sal_Int32 nUserDefPos = SC_AREASDLG_RR_USER;
     sal_Int32 nFirstCustomPos = SC_AREASDLG_RR_OFFSET;
 
     // find edit field for list box, and list box positions
-    if( pLb == pLbPrintArea )
+    if (&rLb == m_xLbPrintArea.get())
     {
-        pEd = pEdPrintArea;
+        pEd = m_xEdPrintArea.get();
         nAllSheetPos = SC_AREASDLG_PR_ENTIRE;
-        nUserDefPos = SC_AREASDLG_PR_USER;
         nFirstCustomPos = SC_AREASDLG_PR_SELECT;    // "Selection" and following
     }
-    else if( pLb == pLbRepeatCol )
-        pEd = pEdRepeatCol;
-    else if( pLb == pLbRepeatRow )
-        pEd = pEdRepeatRow;
+    else if (&rLb == m_xLbRepeatCol.get())
+        pEd = m_xEdRepeatCol.get();
+    else if (&rLb == m_xLbRepeatRow.get())
+        pEd = m_xEdRepeatRow.get();
     else
         return;
 
     // fill edit field according to list box selection
     if( (nSelPos == 0) || (nSelPos == nAllSheetPos) )
         pEd->SetText( EMPTY_OUSTRING );
-    else if( nSelPos == nUserDefPos && !pLb->IsTravelSelect() && pEd->GetText().isEmpty())
-        pLb->SelectEntryPos( 0 );
     else if( nSelPos >= nFirstCustomPos )
-        pEd->SetText( *static_cast< OUString* >( pLb->GetEntryData( nSelPos ) ) );
+        pEd->SetText(rLb.get_id(nSelPos));
 }
 
-IMPL_LINK( ScPrintAreasDlg, Impl_ModifyHdl, Edit&, rEd, void )
+IMPL_LINK( ScPrintAreasDlg, Impl_ModifyHdl, formula::WeldRefEdit&, rEd, void )
 {
-    ListBox* pLb = nullptr;
+    weld::ComboBox* pLb = nullptr;
 
     // list box positions of specific entries, default to "repeat row/column" list boxes
     sal_Int32 nUserDefPos = SC_AREASDLG_RR_USER;
     sal_Int32 nFirstCustomPos = SC_AREASDLG_RR_OFFSET;
 
-    if( &rEd == pEdPrintArea )
+    if( &rEd == m_xEdPrintArea.get() )
     {
-        pLb = pLbPrintArea;
+        pLb = m_xLbPrintArea.get();
         nUserDefPos = SC_AREASDLG_PR_USER;
         nFirstCustomPos = SC_AREASDLG_PR_SELECT;    // "Selection" and following
     }
-    else if( &rEd == pEdRepeatCol )
-        pLb = pLbRepeatCol;
-    else if( &rEd == pEdRepeatRow )
-        pLb = pLbRepeatRow;
+    else if( &rEd == m_xEdRepeatCol.get() )
+        pLb = m_xLbRepeatCol.get();
+    else if( &rEd == m_xEdRepeatRow.get() )
+        pLb = m_xLbRepeatRow.get();
     else
         return;
 
     // set list box selection according to edit field
-    const sal_Int32 nEntryCount = pLb->GetEntryCount();
+    const sal_Int32 nEntryCount = pLb->get_count();
     OUString aStrEd( rEd.GetText() );
     OUString aEdUpper = aStrEd.toAsciiUpperCase();
 
@@ -611,14 +582,14 @@ IMPL_LINK( ScPrintAreasDlg, Impl_ModifyHdl, Edit&, rEd, void )
 
         for ( i=nFirstCustomPos; i<nEntryCount && !bFound; i++ )
         {
-            OUString* pSymbol = static_cast<OUString*>(pLb->GetEntryData( i ));
-            bFound  = ( (*pSymbol)  ==aStrEd || (*pSymbol) == aEdUpper );
+            const OUString& rSymbol = pLb->get_id(i);
+            bFound = (rSymbol == aStrEd || rSymbol == aEdUpper);
         }
 
-        pLb->SelectEntryPos( bFound ? i-1 : nUserDefPos );
+        pLb->set_active( bFound ? i-1 : nUserDefPos );
     }
     else
-        pLb->SelectEntryPos( !aStrEd.isEmpty() ? nUserDefPos : 0 );
+        pLb->set_active( !aStrEd.isEmpty() ? nUserDefPos : 0 );
 }
 
 // global functions:
diff --git a/sc/source/ui/view/reffact.cxx b/sc/source/ui/view/reffact.cxx
index 7d23436d4885..d0831495e9c5 100644
--- a/sc/source/ui/view/reffact.cxx
+++ b/sc/source/ui/view/reffact.cxx
@@ -43,7 +43,7 @@ SFX_IMPL_MODELESSDIALOG_WITHID(ScFilterDlgWrapper, SID_FILTER )
 SFX_IMPL_MODELESSDIALOG_WITHID(ScSpecialFilterDlgWrapper, SID_SPECIAL_FILTER )
 SFX_IMPL_CHILDWINDOW_WITHID(ScDbNameDlgWrapper, SID_DEFINE_DBNAME )
 SFX_IMPL_MODELESSDIALOG_WITHID(ScConsolidateDlgWrapper, SID_OPENDLG_CONSOLIDATE )
-SFX_IMPL_MODELESSDIALOG_WITHID(ScPrintAreasDlgWrapper, SID_OPENDLG_EDIT_PRINTAREA )
+SFX_IMPL_CHILDWINDOW_WITHID(ScPrintAreasDlgWrapper, SID_OPENDLG_EDIT_PRINTAREA )
 SFX_IMPL_MODELESSDIALOG_WITHID(ScColRowNameRangesDlgWrapper, SID_DEFINE_COLROWNAMERANGES )
 SFX_IMPL_MODELESSDIALOG_WITHID(ScFormulaDlgWrapper, SID_OPENDLG_FUNCTION )
 SFX_IMPL_MODELESSDIALOG_WITHID(ScAcceptChgDlgWrapper, FID_CHG_ACCEPT )
@@ -145,7 +145,7 @@ IMPL_CHILD_CTOR( ScColRowNameRangesDlgWrapper, SID_DEFINE_COLROWNAMERANGES )
 
 IMPL_CHILD_CTOR( ScConsolidateDlgWrapper, SID_OPENDLG_CONSOLIDATE )
 
-IMPL_CHILD_CTOR( ScPrintAreasDlgWrapper, SID_OPENDLG_EDIT_PRINTAREA )
+IMPL_CONTROLLER_CHILD_CTOR( ScPrintAreasDlgWrapper, SID_OPENDLG_EDIT_PRINTAREA )
 
 IMPL_CHILD_CTOR( ScFormulaDlgWrapper, SID_OPENDLG_FUNCTION )
 
diff --git a/sc/source/ui/view/tabvwshc.cxx b/sc/source/ui/view/tabvwshc.cxx
index 8fb5c9cdd546..02177d27864e 100644
--- a/sc/source/ui/view/tabvwshc.cxx
+++ b/sc/source/ui/view/tabvwshc.cxx
@@ -288,12 +288,6 @@ VclPtr<SfxModelessDialog> ScTabViewShell::CreateRefDialog(
         }
         break;
 
-        case SID_OPENDLG_EDIT_PRINTAREA:
-        {
-            pResult = VclPtr<ScPrintAreasDlg>::Create( pB, pCW, pParent );
-        }
-        break;
-
         case SID_OPENDLG_FUNCTION:
         {
             // dialog checks, what is in the cell
@@ -495,6 +489,9 @@ std::unique_ptr<SfxModelessDialogController> ScTabViewShell::CreateRefDialogCont
             xResult.reset(new ScDbNameDlg(pB, pCW, pParent, &GetViewData()));
             break;
         }
+        case SID_OPENDLG_EDIT_PRINTAREA:
+            xResult.reset(new ScPrintAreasDlg(pB, pCW, pParent));
+        break;
     }
 
     if (xResult)
diff --git a/sc/uiconfig/scalc/ui/printareasdialog.ui b/sc/uiconfig/scalc/ui/printareasdialog.ui
index a38b9a880d9b..5f81504236e0 100644
--- a/sc/uiconfig/scalc/ui/printareasdialog.ui
+++ b/sc/uiconfig/scalc/ui/printareasdialog.ui
@@ -1,14 +1,18 @@
 <?xml version="1.0" encoding="UTF-8"?>
-<!-- Generated with glade 3.18.3 -->
+<!-- Generated with glade 3.22.1 -->
 <interface domain="sc">
   <requires lib="gtk+" version="3.18"/>
-  <requires lib="LibreOffice" version="1.0"/>
   <object class="GtkDialog" id="PrintAreasDialog">
     <property name="can_focus">False</property>
     <property name="border_width">6</property>
     <property name="title" translatable="yes" context="printareasdialog|PrintAreasDialog">Edit Print Ranges</property>
     <property name="resizable">False</property>
+    <property name="default_width">0</property>
+    <property name="default_height">0</property>
     <property name="type_hint">dialog</property>
+    <child>
+      <placeholder/>
+    </child>
     <child internal-child="vbox">
       <object class="GtkBox" id="internal-box1">
         <property name="can_focus">False</property>
@@ -100,7 +104,7 @@
                         <property name="row_spacing">6</property>
                         <property name="column_spacing">12</property>
                         <child>
-                          <object class="foruilo-RefButton" id="rbprintarea">
+                          <object class="GtkButton" id="rbprintarea">
                             <property name="visible">True</property>
                             <property name="can_focus">False</property>
                             <property name="receives_default">False</property>
@@ -114,10 +118,11 @@
                           </packing>
                         </child>
                         <child>
-                          <object class="foruilo-RefEdit" id="edprintarea">
+                          <object class="GtkEntry" id="edprintarea">
                             <property name="visible">True</property>
                             <property name="can_focus">True</property>
                             <property name="hexpand">True</property>
+                            <property name="activates_default">True</property>
                             <property name="width_chars">50</property>
                           </object>
                           <packing>
@@ -184,10 +189,11 @@
                         <property name="row_spacing">6</property>
                         <property name="column_spacing">12</property>
                         <child>
-                          <object class="foruilo-RefEdit" id="edrepeatrow">
+                          <object class="GtkEntry" id="edrepeatrow">
                             <property name="visible">True</property>
                             <property name="can_focus">True</property>
                             <property name="hexpand">True</property>
+                            <property name="activates_default">True</property>
                             <property name="width_chars">50</property>
                           </object>
                           <packing>
@@ -196,7 +202,7 @@
                           </packing>
                         </child>
                         <child>
-                          <object class="foruilo-RefButton" id="rbrepeatrow">
+                          <object class="GtkButton" id="rbrepeatrow">
                             <property name="visible">True</property>
                             <property name="can_focus">False</property>
                             <property name="receives_default">False</property>
@@ -266,10 +272,11 @@
                         <property name="row_spacing">6</property>
                         <property name="column_spacing">12</property>
                         <child>
-                          <object class="foruilo-RefEdit" id="edrepeatcol">
+                          <object class="GtkEntry" id="edrepeatcol">
                             <property name="visible">True</property>
                             <property name="can_focus">True</property>
                             <property name="hexpand">True</property>
+                            <property name="activates_default">True</property>
                             <property name="width_chars">50</property>
                           </object>
                           <packing>
@@ -278,7 +285,7 @@
                           </packing>
                         </child>
                         <child>
-                          <object class="foruilo-RefButton" id="rbrepeatcol">
+                          <object class="GtkButton" id="rbrepeatcol">
                             <property name="visible">True</property>
                             <property name="can_focus">False</property>
                             <property name="receives_default">False</property>
diff --git a/solenv/sanitizers/ui/modules/scalc.suppr b/solenv/sanitizers/ui/modules/scalc.suppr
index 76b986f6089a..ebe0e9afbe88 100644
--- a/solenv/sanitizers/ui/modules/scalc.suppr
+++ b/solenv/sanitizers/ui/modules/scalc.suppr
@@ -169,9 +169,12 @@ sc/uiconfig/scalc/ui/pivotfilterdialog.ui://GtkLabel[@id='dbarea'] orphan-label
 sc/uiconfig/scalc/ui/pivottablelayoutdialog.ui://GtkLabel[@id='label6'] orphan-label
 sc/uiconfig/scalc/ui/pivottablelayoutdialog.ui://foruilo-RefEdit[@id='destination-edit'] no-labelled-by
 sc/uiconfig/scalc/ui/pivottablelayoutdialog.ui://foruilo-RefEdit[@id='source-edit'] no-labelled-by
-sc/uiconfig/scalc/ui/printareasdialog.ui://foruilo-RefEdit[@id='edprintarea'] no-labelled-by
-sc/uiconfig/scalc/ui/printareasdialog.ui://foruilo-RefEdit[@id='edrepeatrow'] no-labelled-by
-sc/uiconfig/scalc/ui/printareasdialog.ui://foruilo-RefEdit[@id='edrepeatcol'] no-labelled-by
+sc/uiconfig/scalc/ui/printareasdialog.ui://GtkEntry[@id='edprintarea'] no-labelled-by
+sc/uiconfig/scalc/ui/printareasdialog.ui://GtkEntry[@id='edrepeatrow'] no-labelled-by
+sc/uiconfig/scalc/ui/printareasdialog.ui://GtkEntry[@id='edrepeatcol'] no-labelled-by
+sc/uiconfig/scalc/ui/printareasdialog.ui://GtkButton[@id='rbprintarea'] button-no-label
+sc/uiconfig/scalc/ui/printareasdialog.ui://GtkButton[@id='rbrepeatrow'] button-no-label
+sc/uiconfig/scalc/ui/printareasdialog.ui://GtkButton[@id='rbrepeatcol'] button-no-label
 sc/uiconfig/scalc/ui/protectsheetdlg.ui://GtkLabel[@id='protected'] orphan-label
 sc/uiconfig/scalc/ui/protectsheetdlg.ui://GtkLabel[@id='unprotected'] orphan-label
 sc/uiconfig/scalc/ui/protectsheetdlg.ui://GtkLabel[@id='insert-columns'] orphan-label


More information about the Libreoffice-commits mailing list