//对正在操作的文件进行保存
STDMETHODIMP CTHDatabase::Save(void)
{
// TODO: 在此添加实现代码
Acad::ErrorStatus es ;
try{
AcDbDatabase* pCurDb = acdbHostApplicationServices()->workingDatabase();
if(pCurDb == NULL)
{
return Error(L"Fialed to get current docment " ,IID_ITHDatabase,E_FAIL);
}
AcAxDocLock docLock( pCurDb, AcAxDocLock::kCurDocSwitch );
if(docLock.lockStatus() != Acad::eOk)
throw docLock.lockStatus(); //得到被操作dwg文件的数据库
AcDbDatabase* pWorkDb = NULL;
CAcApDocLockServer tempDocLockServer; if(m_strFileName.IsEmpty())
pWorkDb = pCurDb;
else
{
pWorkDb = tempDocLockServer.GetDataBase(m_strFileName);
if(NULL == pWorkDb)
{
CString strErr = L"Fialed To open the " ;
return Error(strErr + m_strFileName,IID_ITHDatabase,E_FAIL);
}
}
//如果当前操作的文件不是ACAD当前活动文档,则进行存盘
if(!m_strFileName.IsEmpty()){
//遍历ACAD所打开的所有文档,如果当前操作的文件已经被ACAD打开,
//那么把此文档切换为活动文档,存盘后在切换到原来的活动文档
AcApDocument* pCurDoc = curDoc();
AcApDocumentIterator* iter = acDocManager->newAcApDocumentIterator();
if (iter) {
AcApDocument* tmpDoc;
for (; !iter->done(); iter->step()) {
tmpDoc = iter->document();
if (tmpDoc)
{
CString strFile(tmpDoc->fileName());
if(m_strFileName.CompareNoCase(strFile) == )
{
es = acDocManager->setCurDocument(tmpDoc, AcAp::kWrite);//切换为活动文档
if(Acad::eOk != es)
{
delete iter;
throw MESSAGE(es);
}
es = tmpDoc->database()->saveAs(m_strFileName);
if(Acad::eOk != es)
{
delete iter;
throw MESSAGE(es);
}
es = acDocManager->unlockDocument(tmpDoc);
if(Acad::eOk != es)
{
delete iter;
throw MESSAGE(es);
}
es = acDocManager->setCurDocument(pCurDoc);//切换到原来的活动文档
if(Acad::eOk != es)
{
delete iter;
throw MESSAGE(es);
}
delete iter;
iter = NULL;
return S_OK;
}
}
}
if(iter != NULL)
{
delete iter;
iter = NULL;
}
}
//如果当前操作的文件没有被ACAD打开,直接保存
es = pWorkDb->saveAs(m_strFileName);
if(Acad::eOk != es)
throw MESSAGE(es);
}
}
catch(const Acad::ErrorStatus)
{
CString strErr = L"Fialed To open the " ;
return Error(strErr + m_strFileName,IID_ITHDatabase,E_FAIL);
} return S_OK;
}

arx对正在操作的文件进行保存的更多相关文章

  1. Python---进阶---文件操作---搜索文件和保存搜索结果

    ### 编写一个程序,用户输入文件名以及开始搜索的路径,搜索该文件是否存在,如果遇到文件夹,则进入该文件夹继续搜索 - input 去接受用户输入的文件名和开始搜索的路径 - os.path.isdi ...

  2. Asp.Net 操作XML文件的增删改查 利用GridView

    不废话,直接上如何利用Asp.NET操作XML文件,并对其属性进行修改,刚开始的时候,是打算使用JS来控制生成XML文件的,但是最后却是无法创建文件,读取文件则没有使用了 index.aspx 文件 ...

  3. 面试问题2:给一个5G的大文件,保存的数据为32位的整型,找到所有出现次数超过两次的数字

    问题描述:给一个5G的大文件,保存的数据为32位的整型,找到所有出现次数超过两次的数字 大数据操作: 解决方法一: 依次遍历文件数据, 开始32二进制清0 每次读取一个数,先和二进制位与,如果为0 则 ...

  4. 用javacsv API 来操作csv文件

    javacsv是国外开发的一个比较好的操作csv文件的API,这里简单讲一下用法. 先下载javacsv2.0.zip的文件,解压后,把javacsv.jar 添加到项目中.  本站下载地址: htt ...

  5. java使用Apache POI操作excel文件

    官方介绍 HSSF is the POI Project's pure Java implementation of the Excel '97(-2007) file format. XSSF is ...

  6. c#操作XML文件的通用方法

    转载地址:http://www.studyofnet.com/news/36.html 原址没找到 sing System; using System.Data; using System.Confi ...

  7. java操作csv文件之javacsv.jar应用

    csv文件是分隔文件,如果使用java的io流来写,比较麻烦,这里为大家提供一个javacsv的jar包,这个很方便操作csv文件. 下载地址:https://pan.baidu.com/s/1i46 ...

  8. C#操作Excel文件(转)

    摘要:本文介绍了Excel对象.C#中的受管代码和非受管代码,并介绍了COM组件在.net环境中的使用. 关键词:受管代码:非受管代码:Excel对象:动态连接库 引言 Excel是微软公司办公自动化 ...

  9. Java操作属性文件,支持新增或更新多个属性

    Java操作属性文件.支持新增或更新多个属性 一.更新或新增单个属性的方法 /** * 写入properties信息 * @param filePath 绝对路径(包含文件名称和后缀名) * @par ...

随机推荐

  1. sqlserver修改计算机名称。

    SELECT @@SERVERNAME As [@@SERVERNAME], CAST(SERVERPROPERTY('MACHINENAME') AS VARCHAR(128)) + COALESC ...

  2. Web项目发布的一些设置

    比如我们有个项目想要发布到互联网上,我们首先需要购买域名以及主机,主机的话,推荐云主机(本人推荐西部数码或者阿里云),性能好: 我们先在云主机上搭建环境,比如Mysql,Jdk,Tomcat: 然后我 ...

  3. JavaSrcipt的数字(number):深入理解内部机制

    一.数字的语法 JavaScript中的数字字面量一般用十进制表示.在JavaScript中表示数字的数据类型只有一种Number,这种天使与魔鬼同体的数据类型也就只有js了. //同时表达整数和浮点 ...

  4. springBoot的事物管理

    springBoot的事物管理 1:springBoot 整合单数据源事物: Spring Boot 使用事务非常简单,首先使用注解 @EnableTransactionManagement 开启事务 ...

  5. 如何使用Cygwin在Windows上运行OpenSSH SSHD服务器

    记录几款非常有趣, 但不怎么耳熟的软件: Cygwin 是可以安装 OpenSSH server 和 client 的, Mosh 也可以, 这对于 Linux 用户而言就非常方便了. 如何使用Cyg ...

  6. 割点判断+luogu 3469 POI2008 BLO

    1.根节点,有2棵及以上子树 2.非根节点,有子节点dfn[u]<=low[v] #include <bits/stdc++.h> #define N 1000050 using n ...

  7. 【Python】Xml To Excel

    [Python3] 之前做的入门练习里有一题将excel文件转化为xml文件,这回补上逆向转换→xml to excel 用的还是beautifulsoup. 主要还是:①读取待处理文件文本内容 ②处 ...

  8. python基础 range()与np.arange()

    range()返回的是range object,而np.nrange()返回的是numpy.ndarray() range尽可用于迭代,而np.nrange作用远不止于此,它是一个序列,可被当做向量使 ...

  9. 第25月第9天 tf_tang_poems kaggle

    1.neural-style https://github.com/anishathalye/neural-style wget http://www.vlfeat.org/matconvnet/mo ...

  10. Element-ui 中dialog的使用方法

    <template> <div> <el-button type="text" @click="dialogFormVisible = tr ...