/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * This file incorporates work covered by the following license notice: * * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed * with this work for additional information regarding copyright * ownership. The ASF licenses this file to you under the Apache * License, Version 2.0 (the "License"); you may not use this file * except in compliance with the License. You may obtain a copy of * the License at http://www.apache.org/licenses/LICENSE-2.0 . */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include // text grid #include #include using namespace ::com::sun::star::i18n; using namespace ::com::sun::star::lang; using namespace ::com::sun::star::uno; using namespace ::com::sun::star; // Load Document bool SwDocShell::InitNew( const uno::Reference < embed::XStorage >& xStor ) { bool bRet = SfxObjectShell::InitNew( xStor ); OSL_ENSURE( GetMapUnit() == MapUnit::MapTwip, "map unit is not twip!" ); bool bHTMLTemplSet = false; if( bRet ) { AddLink(); // create m_pDoc / pIo if applicable bool bWeb = dynamic_cast< const SwWebDocShell *>( this ) != nullptr; if ( bWeb ) bHTMLTemplSet = SetHTMLTemplate( *GetDoc() );// Styles from HTML.vor else if( dynamic_cast< const SwGlobalDocShell *>( this ) != nullptr ) GetDoc()->getIDocumentSettingAccess().set(DocumentSettingId::GLOBAL_DOCUMENT, true); // Globaldokument if ( GetCreateMode() == SfxObjectCreateMode::EMBEDDED ) SwTransferable::InitOle( this, *m_pDoc ); // set forbidden characters if necessary if (!utl::ConfigManager::IsAvoidConfig()) { SvxAsianConfig aAsian; Sequence aLocales = aAsian.GetStartEndCharLocales(); if (aLocales.getLength()) { const lang::Locale* pLocales = aLocales.getConstArray(); for(sal_Int32 i = 0; i < aLocales.getLength(); i++) { ForbiddenCharacters aForbidden; aAsian.GetStartEndChars( pLocales[i], aForbidden.beginLine, aForbidden.endLine); LanguageType eLang = LanguageTag::convertToLanguageType(pLocales[i]); m_pDoc->getIDocumentSettingAccess().setForbiddenCharacters( eLang, aForbidden); } } m_pDoc->getIDocumentSettingAccess().set(DocumentSettingId::KERN_ASIAN_PUNCTUATION, !aAsian.IsKerningWesternTextOnly()); m_pDoc->getIDocumentSettingAccess().setCharacterCompressionType(static_cast(aAsian.GetCharDistanceCompression())); m_pDoc->getIDocumentDeviceAccess().setPrintData(*SW_MOD()->GetPrtOptions(bWeb)); } SubInitNew(); // for all SwStdFontConfig* pStdFont = SW_MOD()->GetStdFontConfig(); SfxPrinter* pPrt = m_pDoc->getIDocumentDeviceAccess().getPrinter( false ); OUString sEntry; static const sal_uInt16 aFontWhich[] = { RES_CHRATR_FONT, RES_CHRATR_CJK_FONT, RES_CHRATR_CTL_FONT }; static const sal_uInt16 aFontHeightWhich[] = { RES_CHRATR_FONTSIZE, RES_CHRATR_CJK_FONTSIZE, RES_CHRATR_CTL_FONTSIZE }; static const sal_uInt16 aFontIds[] = { FONT_STANDARD, FONT_STANDARD_CJK, FONT_STANDARD_CTL }; static const DefaultFontType nFontTypes[] = { DefaultFontType::LATIN_TEXT, DefaultFontType::CJK_TEXT, DefaultFontType::CTL_TEXT }; static const sal_uInt16 aLangTypes[] = { RES_CHRATR_LANGUAGE, RES_CHRATR_CJK_LANGUAGE, RES_CHRATR_CTL_LANGUAGE }; for(sal_uInt8 i = 0; i < 3; i++) { sal_uInt16 nFontWhich = aFontWhich[i]; sal_uInt16 nFontId = aFontIds[i]; std::unique_ptr pFontItem; const SvxLanguageItem& rLang = static_cast(m_pDoc->GetDefault( aLangTypes[i] )); LanguageType eLanguage = rLang.GetLanguage(); if(!pStdFont->IsFontDefault(nFontId)) { sEntry = pStdFont->GetFontFor(nFontId); vcl::Font aFont( sEntry, Size( 0, 10 ) ); if( pPrt ) { aFont = pPrt->GetFontMetric( aFont ); } pFontItem.reset(new SvxFontItem(aFont.GetFamilyType(), aFont.GetFamilyName(), aEmptyOUStr, aFont.GetPitch(), aFont.GetCharSet(), nFontWhich)); } else { // #107782# OJ use korean language if latin was used if ( i == 0 ) { LanguageType eUiLanguage = Application::GetSettings().GetUILanguageTag().getLanguageType(); if (MsLangId::isKorean(eUiLanguage)) eLanguage = eUiLanguage; } vcl::Font aLangDefFont = OutputDevice::GetDefaultFont( nFontTypes[i], eLanguage, GetDefaultFontFlags::OnlyOne ); pFontItem.reset(new SvxFontItem(aLangDefFont.GetFamilyType(), aLangDefFont.GetFamilyName(), aEmptyOUStr, aLangDefFont.GetPitch(), aLangDefFont.GetCharSet(), nFontWhich)); } m_pDoc->SetDefault(*pFontItem); if( !bHTMLTemplSet ) { SwTextFormatColl *pColl = m_pDoc->getIDocumentStylePoolAccess().GetTextCollFromPool(RES_POOLCOLL_STANDARD); pColl->ResetFormatAttr(nFontWhich); } pFontItem.reset(); sal_Int32 nFontHeight = pStdFont->GetFontHeight( FONT_STANDARD, i, eLanguage ); if(nFontHeight <= 0) nFontHeight = SwStdFontConfig::GetDefaultHeightFor( nFontId, eLanguage ); m_pDoc->SetDefault(SvxFontHeightItem( nFontHeight, 100, aFontHeightWhich[i] )); if( !bHTMLTemplSet ) { SwTextFormatColl *pColl = m_pDoc->getIDocumentStylePoolAccess().GetTextCollFromPool(RES_POOLCOLL_STANDARD); pColl->ResetFormatAttr(aFontHeightWhich[i]); } } sal_uInt16 aFontIdPoolId[] = { FONT_OUTLINE, RES_POOLCOLL_HEADLINE_BASE, FONT_LIST, RES_POOLCOLL_NUMBUL_BASE, FONT_CAPTION, RES_POOLCOLL_LABEL, FONT_INDEX, RES_POOLCOLL_REGISTER_BASE, FONT_OUTLINE_CJK, RES_POOLCOLL_HEADLINE_BASE, FONT_LIST_CJK, RES_POOLCOLL_NUMBUL_BASE, FONT_CAPTION_CJK, RES_POOLCOLL_LABEL, FONT_INDEX_CJK, RES_POOLCOLL_REGISTER_BASE, FONT_OUTLINE_CTL, RES_POOLCOLL_HEADLINE_BASE, FONT_LIST_CTL, RES_POOLCOLL_NUMBUL_BASE, FONT_CAPTION_CTL, RES_POOLCOLL_LABEL, FONT_INDEX_CTL, RES_POOLCOLL_REGISTER_BASE }; sal_uInt16 nFontWhich = RES_CHRATR_FONT; sal_uInt16 nFontHeightWhich = RES_CHRATR_FONTSIZE; LanguageType eLanguage = static_cast(m_pDoc->GetDefault( RES_CHRATR_LANGUAGE )).GetLanguage(); for(sal_uInt8 nIdx = 0; nIdx < 24; nIdx += 2) { if(nIdx == 8) { nFontWhich = RES_CHRATR_CJK_FONT; nFontHeightWhich = RES_CHRATR_CJK_FONTSIZE; eLanguage = static_cast(m_pDoc->GetDefault( RES_CHRATR_CJK_LANGUAGE )).GetLanguage(); } else if(nIdx == 16) { nFontWhich = RES_CHRATR_CTL_FONT; nFontHeightWhich = RES_CHRATR_CTL_FONTSIZE; eLanguage = static_cast(m_pDoc->GetDefault( RES_CHRATR_CTL_LANGUAGE )).GetLanguage(); } SwTextFormatColl *pColl = nullptr; if(!pStdFont->IsFontDefault(aFontIdPoolId[nIdx])) { sEntry = pStdFont->GetFontFor(aFontIdPoolId[nIdx]); vcl::Font aFont( sEntry, Size( 0, 10 ) ); if( pPrt ) aFont = pPrt->GetFontMetric( aFont ); pColl = m_pDoc->getIDocumentStylePoolAccess().GetTextCollFromPool(aFontIdPoolId[nIdx + 1]); if( !bHTMLTemplSet || SfxItemState::SET != pColl->GetAttrSet().GetItemState( nFontWhich, false ) ) { pColl->SetFormatAttr(SvxFontItem(aFont.GetFamilyType(), aFont.GetFamilyName(), aEmptyOUStr, aFont.GetPitch(), aFont.GetCharSet(), nFontWhich)); } } sal_Int32 nFontHeight = pStdFont->GetFontHeight( static_cast< sal_Int8 >(aFontIdPoolId[nIdx]), 0, eLanguage ); if(nFontHeight <= 0) nFontHeight = SwStdFontConfig::GetDefaultHeightFor( aFontIdPoolId[nIdx], eLanguage ); if(!pColl) pColl = m_pDoc->getIDocumentStylePoolAccess().GetTextCollFromPool(aFontIdPoolId[nIdx + 1]); SvxFontHeightItem aFontHeight( static_cast(pColl->GetFormatAttr( nFontHeightWhich ))); if(aFontHeight.GetHeight() != sal::static_int_cast(nFontHeight)) { aFontHeight.SetHeight(nFontHeight); pColl->SetFormatAttr( aFontHeight ); } } // the default for documents created via 'File/New' should be 'on' // (old documents, where this property was not yet implemented, will get the // value 'false' in the SwDoc c-tor) m_pDoc->getIDocumentSettingAccess().set( DocumentSettingId::MATH_BASELINE_ALIGNMENT, SW_MOD()->GetUsrPref( bWeb )->IsAlignMathObjectsToBaseline() ); } /* #106748# If the default frame direction of a document is RTL the default adjustment is to the right. */ if( !bHTMLTemplSet && FRMDIR_HORI_RIGHT_TOP == GetDefaultFrameDirection(GetAppLanguage()) ) { m_pDoc->SetDefault( SvxAdjustItem(SVX_ADJUST_RIGHT, RES_PARATR_ADJUST ) ); } // #i29550# m_pDoc->SetDefault( SfxBoolItem( RES_COLLAPSING_BORDERS, true ) ); // <-- collapsing //#i16874# AutoKerning as default for new documents m_pDoc->SetDefault( SvxAutoKernItem( true, RES_CHRATR_AUTOKERN ) ); // #i42080# - Due to the several calls of method // at the document instance, the document is modified. Thus, reset this // status here. Note: In method this is also done. m_pDoc->getIDocumentState().ResetModified(); return bRet; } // Ctor with SfxCreateMode ????? SwDocShell::SwDocShell( SfxObjectCreateMode const eMode ) : SfxObjectShell(eMode) , m_pDoc(nullptr) , m_pFontList(nullptr) , m_IsInUpdateFontList(false) , m_pStyleManager(new svx::CommonStyleManager(*this)) , m_pView(nullptr) , m_pWrtShell(nullptr) , m_pOLEChildList(nullptr) , m_nUpdateDocMode(document::UpdateDocMode::ACCORDING_TO_CONFIG) , m_IsATemplate(false) , m_IsRemovedInvisibleContent(false) { Init_Impl(); } // Ctor / Dtor SwDocShell::SwDocShell( const SfxModelFlags i_nSfxCreationFlags ) : SfxObjectShell ( i_nSfxCreationFlags ) , m_pDoc(nullptr) , m_pFontList(nullptr) , m_IsInUpdateFontList(false) , m_pStyleManager(new svx::CommonStyleManager(*this)) , m_pView(nullptr) , m_pWrtShell(nullptr) , m_pOLEChildList(nullptr) , m_nUpdateDocMode(document::UpdateDocMode::ACCORDING_TO_CONFIG) , m_IsATemplate(false) , m_IsRemovedInvisibleContent(false) { Init_Impl(); } // Ctor / Dtor SwDocShell::SwDocShell( SwDoc *const pD, SfxObjectCreateMode const eMode ) : SfxObjectShell(eMode) , m_pDoc(pD) , m_pFontList(nullptr) , m_IsInUpdateFontList(false) , m_pStyleManager(new svx::CommonStyleManager(*this)) , m_pView(nullptr) , m_pWrtShell(nullptr) , m_pOLEChildList(nullptr) , m_nUpdateDocMode(document::UpdateDocMode::ACCORDING_TO_CONFIG) , m_IsATemplate(false) , m_IsRemovedInvisibleContent(false) { Init_Impl(); } // Dtor SwDocShell::~SwDocShell() { // disable chart related objects now because in ~SwDoc it may be to late for this if (m_pDoc) { m_pDoc->getIDocumentChartDataProviderAccess().GetChartControllerHelper().Disconnect(); SwChartDataProvider *pPCD = m_pDoc->getIDocumentChartDataProviderAccess().GetChartDataProvider(); if (pPCD) pPCD->dispose(); } RemoveLink(); delete m_pFontList; // we, as BroadCaster also become our own Listener // (for DocInfo/FileNames/....) EndListening( *this ); delete m_pOLEChildList; } void SwDocShell::Init_Impl() { SetPool(&SW_MOD()->GetPool()); SetBaseModel(new SwXTextDocument(this)); // we, as BroadCaster also become our own Listener // (for DocInfo/FileNames/....) StartListening( *this ); //position of the "Automatic" style filter for the stylist (app.src) SetAutoStyleFilterIndex(3); // set map unit to twip SetMapUnit( MapUnit::MapTwip ); } void SwDocShell::AddLink() { if (!m_pDoc) { SwDocFac aFactory; m_pDoc = aFactory.GetDoc(); m_pDoc->acquire(); m_pDoc->getIDocumentSettingAccess().set(DocumentSettingId::HTML_MODE, dynamic_cast< const SwWebDocShell *>( this ) != nullptr ); } else m_pDoc->acquire(); m_pDoc->SetDocShell( this ); // set the DocShell-Pointer for Doc uno::Reference< text::XTextDocument > xDoc(GetBaseModel(), uno::UNO_QUERY); static_cast(xDoc.get())->Reactivate(this); SetPool(&m_pDoc->GetAttrPool()); // most suitably not until a sdbcx::View is created!!! m_pDoc->SetOle2Link(LINK(this, SwDocShell, Ole2ModifiedHdl)); } // create new FontList Change Printer void SwDocShell::UpdateFontList() { if (!m_IsInUpdateFontList) { m_IsInUpdateFontList = true; OSL_ENSURE(m_pDoc, "No Doc no FontList"); if (m_pDoc) { delete m_pFontList; m_pFontList = new FontList( m_pDoc->getIDocumentDeviceAccess().getReferenceDevice(true) ); PutItem( SvxFontListItem( m_pFontList, SID_ATTR_CHAR_FONTLIST ) ); } m_IsInUpdateFontList = false; } } void SwDocShell::RemoveLink() { // disconnect Uno-Object uno::Reference< text::XTextDocument > xDoc(GetBaseModel(), uno::UNO_QUERY); static_cast(xDoc.get())->Invalidate(); if (m_pDoc) { if (m_xBasePool.is()) { static_cast(m_xBasePool.get())->dispose(); m_xBasePool.clear(); } sal_Int8 nRefCt = static_cast< sal_Int8 >(m_pDoc->release()); m_pDoc->SetOle2Link(Link()); m_pDoc->SetDocShell( nullptr ); if( !nRefCt ) delete m_pDoc; m_pDoc = nullptr; // we don't have the Doc anymore!! } } void SwDocShell::InvalidateModel() { // disconnect Uno-Object uno::Reference< text::XTextDocument > xDoc(GetBaseModel(), uno::UNO_QUERY); static_cast(xDoc.get())->Invalidate(); } void SwDocShell::ReactivateModel() { // disconnect Uno-Object uno::Reference< text::XTextDocument > xDoc(GetBaseModel(), uno::UNO_QUERY); static_cast(xDoc.get())->Reactivate(this); } // Load, Default-Format bool SwDocShell::Load( SfxMedium& rMedium ) { bool bRet = false; // If this is an ODF file being loaded, then by default, use legacy processing // for tdf#99729 (if required, it will be overriden in *::ReadUserDataSequence()) if (IsOwnStorageFormat(rMedium)) { if (m_pDoc && m_pDoc->getIDocumentDrawModelAccess().GetDrawModel()) m_pDoc->getIDocumentDrawModelAccess().GetDrawModel()->SetAnchoredTextOverflowLegacy(true); } if (SfxObjectShell::Load(rMedium)) { comphelper::EmbeddedObjectContainer& rEmbeddedObjectContainer = getEmbeddedObjectContainer(); rEmbeddedObjectContainer.setUserAllowsLinkUpdate(false); SAL_INFO( "sw.ui", "after SfxInPlaceObject::Load" ); if (m_pDoc) // for last version!! RemoveLink(); // release the existing AddLink(); // set Link and update Data!! // Loading // for MD OSL_ENSURE( !m_xBasePool.is(), "who hasn't destroyed their Pool?" ); m_xBasePool = new SwDocStyleSheetPool( *m_pDoc, SfxObjectCreateMode::ORGANIZER == GetCreateMode() ); if(GetCreateMode() != SfxObjectCreateMode::ORGANIZER) { const SfxUInt16Item* pUpdateDocItem = SfxItemSet::GetItem(rMedium.GetItemSet(), SID_UPDATEDOCMODE, false); m_nUpdateDocMode = pUpdateDocItem ? pUpdateDocItem->GetValue() : document::UpdateDocMode::NO_UPDATE; } SwWait aWait( *this, true ); sal_uInt32 nErr = ERR_SWG_READ_ERROR; switch( GetCreateMode() ) { case SfxObjectCreateMode::ORGANIZER: { if( ReadXML ) { ReadXML->SetOrganizerMode( true ); SwReader aRdr( rMedium, aEmptyOUStr, m_pDoc ); nErr = aRdr.Read( *ReadXML ); ReadXML->SetOrganizerMode( false ); } } break; case SfxObjectCreateMode::INTERNAL: case SfxObjectCreateMode::EMBEDDED: { SwTransferable::InitOle( this, *m_pDoc ); } // suppress SfxProgress, when we are Embedded SW_MOD()->SetEmbeddedLoadSave( true ); SAL_FALLTHROUGH; case SfxObjectCreateMode::STANDARD: case SfxObjectCreateMode::PREVIEW: { Reader *pReader = ReadXML; if( pReader ) { // set Doc's DocInfo at DocShell-Medium SAL_INFO( "sw.ui", "before ReadDocInfo" ); SwReader aRdr( rMedium, aEmptyOUStr, m_pDoc ); SAL_INFO( "sw.ui", "before Read" ); nErr = aRdr.Read( *pReader ); SAL_INFO( "sw.ui", "after Read" ); // If a XML document is loaded, the global doc/web doc // flags have to be set, because they aren't loaded // by this formats. if( dynamic_cast< const SwWebDocShell *>( this ) != nullptr ) { if (!m_pDoc->getIDocumentSettingAccess().get(DocumentSettingId::HTML_MODE)) m_pDoc->getIDocumentSettingAccess().set(DocumentSettingId::HTML_MODE, true); } if( dynamic_cast< const SwGlobalDocShell *>( this ) != nullptr ) { if (!m_pDoc->getIDocumentSettingAccess().get(DocumentSettingId::GLOBAL_DOCUMENT)) m_pDoc->getIDocumentSettingAccess().set(DocumentSettingId::GLOBAL_DOCUMENT, true); } } } break; default: OSL_ENSURE( false, "Load: new CreateMode?" ); } UpdateFontList(); InitDrawModelAndDocShell(this, m_pDoc ? m_pDoc->getIDocumentDrawModelAccess().GetDrawModel() : nullptr); SetError( nErr, OSL_LOG_PREFIX ); bRet = !IsError( nErr ); if (bRet && !m_pDoc->IsInLoadAsynchron() && GetCreateMode() == SfxObjectCreateMode::STANDARD) { LoadingFinished(); } // suppress SfxProgress, when we are Embedded SW_MOD()->SetEmbeddedLoadSave( false ); } return bRet; } bool SwDocShell::LoadFrom( SfxMedium& rMedium ) { bool bRet = false; if (m_pDoc) RemoveLink(); AddLink(); // set Link and update Data!! do { // middle check loop sal_uInt32 nErr = ERR_SWG_READ_ERROR; OUString aStreamName = "styles.xml"; uno::Reference < container::XNameAccess > xAccess( rMedium.GetStorage(), uno::UNO_QUERY ); if ( xAccess->hasByName( aStreamName ) && rMedium.GetStorage()->isStreamElement( aStreamName ) ) { // Loading SwWait aWait( *this, true ); { OSL_ENSURE( !m_xBasePool.is(), "who hasn't destroyed their Pool?" ); m_xBasePool = new SwDocStyleSheetPool( *m_pDoc, SfxObjectCreateMode::ORGANIZER == GetCreateMode() ); if( ReadXML ) { ReadXML->SetOrganizerMode( true ); SwReader aRdr( rMedium, aEmptyOUStr, m_pDoc ); nErr = aRdr.Read( *ReadXML ); ReadXML->SetOrganizerMode( false ); } } } else { OSL_FAIL("Code removed!"); } SetError( nErr, OSL_LOG_PREFIX ); bRet = !IsError( nErr ); } while( false ); SfxObjectShell::LoadFrom( rMedium ); m_pDoc->getIDocumentState().ResetModified(); return bRet; } void SwDocShell::SubInitNew() { OSL_ENSURE( !m_xBasePool.is(), "who hasn't destroyed their Pool?" ); m_xBasePool = new SwDocStyleSheetPool( *m_pDoc, SfxObjectCreateMode::ORGANIZER == GetCreateMode() ); UpdateFontList(); InitDrawModelAndDocShell(this, m_pDoc ? m_pDoc->getIDocumentDrawModelAccess().GetDrawModel() : nullptr); m_pDoc->getIDocumentSettingAccess().setLinkUpdateMode( GLOBALSETTING ); m_pDoc->getIDocumentSettingAccess().setFieldUpdateFlags( AUTOUPD_GLOBALSETTING ); bool bWeb = dynamic_cast< const SwWebDocShell *>( this ) != nullptr; sal_uInt16 nRange[] = { RES_PARATR_ADJUST, RES_PARATR_ADJUST, RES_CHRATR_COLOR, RES_CHRATR_COLOR, RES_CHRATR_LANGUAGE, RES_CHRATR_LANGUAGE, RES_CHRATR_CJK_LANGUAGE, RES_CHRATR_CJK_LANGUAGE, RES_CHRATR_CTL_LANGUAGE, RES_CHRATR_CTL_LANGUAGE, 0, 0, 0 }; if(!bWeb) { nRange[ SAL_N_ELEMENTS(nRange) - 3 ] = RES_PARATR_TABSTOP; nRange[ SAL_N_ELEMENTS(nRange) - 2 ] = RES_PARATR_HYPHENZONE; } SfxItemSet aDfltSet( m_pDoc->GetAttrPool(), nRange ); //! get lingu options without loading lingu DLL SvtLinguOptions aLinguOpt; if (!utl::ConfigManager::IsAvoidConfig()) SvtLinguConfig().GetOptions(aLinguOpt); sal_Int16 nVal = MsLangId::resolveSystemLanguageByScriptType(aLinguOpt.nDefaultLanguage, css::i18n::ScriptType::LATIN), eCJK = MsLangId::resolveSystemLanguageByScriptType(aLinguOpt.nDefaultLanguage_CJK, css::i18n::ScriptType::ASIAN), eCTL = MsLangId::resolveSystemLanguageByScriptType(aLinguOpt.nDefaultLanguage_CTL, css::i18n::ScriptType::COMPLEX); aDfltSet.Put( SvxLanguageItem( nVal, RES_CHRATR_LANGUAGE ) ); aDfltSet.Put( SvxLanguageItem( eCJK, RES_CHRATR_CJK_LANGUAGE ) ); aDfltSet.Put( SvxLanguageItem( eCTL, RES_CHRATR_CTL_LANGUAGE ) ); if(!bWeb) { SvxHyphenZoneItem aHyp( static_cast( m_pDoc->GetDefault( RES_PARATR_HYPHENZONE) ) ); aHyp.GetMinLead() = static_cast< sal_uInt8 >(aLinguOpt.nHyphMinLeading); aHyp.GetMinTrail() = static_cast< sal_uInt8 >(aLinguOpt.nHyphMinTrailing); aDfltSet.Put( aHyp ); sal_uInt16 nNewPos = static_cast< sal_uInt16 >(SW_MOD()->GetUsrPref(false)->GetDefTab()); if( nNewPos ) aDfltSet.Put( SvxTabStopItem( 1, nNewPos, SvxTabAdjust::Default, RES_PARATR_TABSTOP ) ); } aDfltSet.Put( SvxColorItem( Color( COL_AUTO ), RES_CHRATR_COLOR ) ); m_pDoc->SetDefault( aDfltSet ); //default page mode for text grid if(!bWeb) { bool bSquaredPageMode = SW_MOD()->GetUsrPref(false)->IsSquaredPageMode(); m_pDoc->SetDefaultPageMode( bSquaredPageMode ); // only set Widow/Orphan defaults on a new, non-web document - not an opened one if( GetMedium() && GetMedium()->GetOrigURL().isEmpty() ) { m_pDoc->SetDefault( SvxWidowsItem( (sal_uInt8) 2, RES_PARATR_WIDOWS) ); m_pDoc->SetDefault( SvxOrphansItem( (sal_uInt8) 2, RES_PARATR_ORPHANS) ); } } m_pDoc->getIDocumentState().ResetModified(); } /* * Document Interface Access */ IDocumentDeviceAccess& SwDocShell::getIDocumentDeviceAccess() { return m_pDoc->getIDocumentDeviceAccess(); } IDocumentChartDataProviderAccess& SwDocShell::getIDocumentChartDataProviderAccess() { return m_pDoc->getIDocumentChartDataProviderAccess(); } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */