|
|
/*
|
|
|
* Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
|
|
|
*
|
|
|
* Licensed 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
|
|
|
*
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
* See the License for the specific language governing permissions and
|
|
|
* limitations under the License.
|
|
|
*/
|
|
|
|
|
|
package net.micode.notes.gtask.data;
|
|
|
|
|
|
import android.database.Cursor;
|
|
|
|
|
|
import org.json.JSONObject;
|
|
|
|
|
|
// Node类被定义为抽象类,意味着它不能被直接实例化,通常是作为其他具体类的基类,用于定义一些通用的行为和属性
|
|
|
public abstract class Node {
|
|
|
|
|
|
// 定义一系列表示同步操作动作类型的常量,方便在代码中清晰地表示不同的同步相关行为
|
|
|
public static final int SYNC_ACTION_NONE = 0;
|
|
|
public static final int SYNC_ACTION_ADD_REMOTE = 1;
|
|
|
public static final int SYNC_ACTION_ADD_LOCAL = 2;
|
|
|
public static final int SYNC_ACTION_DEL_REMOTE = 3;
|
|
|
public static final int SYNC_ACTION_DEL_LOCAL = 4;
|
|
|
public static final int SYNC_ACTION_UPDATE_REMOTE = 5;
|
|
|
public static final int SYNC_ACTION_UPDATE_LOCAL = 6;
|
|
|
public static final int SYNC_ACTION_UPDATE_CONFLICT = 7;
|
|
|
public static final int SYNC_ACTION_ERROR = 8;
|
|
|
|
|
|
// 用于存储节点的唯一标识符(可能是全局唯一的,具体取决于业务场景),初始化为null
|
|
|
private String mGid;
|
|
|
|
|
|
// 用于存储节点的名称,初始化为空字符串
|
|
|
private String mName;
|
|
|
|
|
|
// 用于记录节点最后一次被修改的时间戳,初始化为0
|
|
|
private long mLastModified;
|
|
|
|
|
|
// 用于标记该节点是否已被删除,初始化为false
|
|
|
private boolean mDeleted;
|
|
|
|
|
|
// 构造函数,在创建Node对象时初始化各个属性的默认值
|
|
|
public Node() {
|
|
|
mGid = null;
|
|
|
mName = "";
|
|
|
mLastModified = 0;
|
|
|
mDeleted = false;
|
|
|
}
|
|
|
|
|
|
// 抽象方法,用于获取创建操作对应的JSONObject,具体的创建操作逻辑由继承该抽象类的具体子类去实现,参数actionId可能用于指定具体的创建操作类型等细节
|
|
|
public abstract JSONObject getCreateAction(int actionId);
|
|
|
|
|
|
// 抽象方法,用于获取更新操作对应的JSONObject,同样具体更新操作逻辑由子类实现,参数actionId用于细化更新操作的相关情况
|
|
|
public abstract JSONObject getUpdateAction(int actionId);
|
|
|
|
|
|
// 抽象方法,根据远程的JSON对象来设置该节点的内容,子类需要根据实际情况解析JSON并正确设置自身的相关属性
|
|
|
public abstract void setContentByRemoteJSON(JSONObject js);
|
|
|
|
|
|
// 抽象方法,根据本地的JSON对象来设置该节点的内容,与上述设置远程JSON内容的方法类似,由子类去具体实现相应逻辑
|
|
|
public abstract void setContentByLocalJSON(JSONObject js);
|
|
|
|
|
|
// 抽象方法,从该节点的内容中获取本地JSON表示形式,也就是将节点自身的属性等信息转换为JSONObject返回,由子类实现具体转换逻辑
|
|
|
public abstract JSONObject getLocalJSONFromContent();
|
|
|
|
|
|
// 抽象方法,根据给定的数据库游标(Cursor)来获取该节点对应的同步操作类型,具体如何根据游标内容判断同步操作由子类确定
|
|
|
public abstract int getSyncAction(Cursor c);
|
|
|
|
|
|
// 设置节点的唯一标识符(Gid)的方法
|
|
|
public void setGid(String gid) {
|
|
|
this.mGid = gid;
|
|
|
}
|
|
|
|
|
|
// 设置节点名称的方法
|
|
|
public void setName(String name) {
|
|
|
this.mName = name;
|
|
|
}
|
|
|
|
|
|
// 设置节点最后修改时间戳的方法
|
|
|
public void setLastModified(long lastModified) {
|
|
|
this.mLastModified = lastModified;
|
|
|
}
|
|
|
|
|
|
// 设置节点是否被删除状态的方法
|
|
|
public void setDeleted(boolean deleted) {
|
|
|
this.mDeleted = deleted;
|
|
|
}
|
|
|
|
|
|
// 获取节点唯一标识符(Gid)的方法
|
|
|
public String getGid() {
|
|
|
return this.mGid;
|
|
|
}
|
|
|
|
|
|
// 获取节点名称的方法
|
|
|
public String getName() {
|
|
|
return this.mName;
|
|
|
}
|
|
|
|
|
|
// 获取节点最后修改时间戳的方法
|
|
|
public long getLastModified() {
|
|
|
return this.mLastModified;
|
|
|
}
|
|
|
|
|
|
// 获取节点是否被删除状态的方法
|
|
|
public boolean getDeleted() {
|
|
|
return this.mDeleted;
|
|
|
}
|
|
|
} |