diff --git a/src/Notes-master/src/net/micode/notes/gtask/data/Task.java b/src/Notes-master/src/net/micode/notes/gtask/data/Task.java index 6a19454..af70895 100644 --- a/src/Notes-master/src/net/micode/notes/gtask/data/Task.java +++ b/src/Notes-master/src/net/micode/notes/gtask/data/Task.java @@ -1,21 +1,4 @@ -/* - * 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 android.text.TextUtils; import android.util.Log; @@ -31,20 +14,23 @@ import org.json.JSONArray; import org.json.JSONException; import org.json.JSONObject; - +// 定义Task类,继承自Node类,代表一个任务相关的实体,可能用于任务管理等功能,比如和远程或本地数据交互来处理任务信息 public class Task extends Node { + // 用于日志输出的标签,方便在日志中识别是这个类输出的相关信息,值为类的简单名称 private static final String TAG = Task.class.getSimpleName(); + // 表示任务是否已完成的布尔变量,初始化为false private boolean mCompleted; - + // 用于存储任务相关备注信息的字符串,初始化为null private String mNotes; - + // 用于存储任务元信息的JSON对象,初始化为null private JSONObject mMetaInfo; - + // 指向该任务的前一个兄弟任务的引用,初始化为null private Task mPriorSibling; - + // 指向该任务所属的父任务列表的引用,初始化为null private TaskList mParent; + // 任务类的默认构造函数,初始化任务的各项属性 public Task() { super(); mCompleted = false; @@ -54,47 +40,54 @@ public class Task extends Node { mMetaInfo = null; } + // 根据给定的actionId创建一个用于表示创建任务操作的JSONObject对象 public JSONObject getCreateAction(int actionId) { JSONObject js = new JSONObject(); try { - // action_type + // 设置action_type字段,表示操作类型为创建任务,使用GTaskStringUtils中定义的常量 js.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE, GTaskStringUtils.GTASK_JSON_ACTION_TYPE_CREATE); - // action_id + // 设置action_id字段,传入给定的actionId js.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, actionId); - // index + // 设置index字段,通过父任务列表获取该任务在其中的索引位置 js.put(GTaskStringUtils.GTASK_JSON_INDEX, mParent.getChildTaskIndex(this)); - // entity_delta + // 创建一个表示任务实体信息的JSONObject对象 JSONObject entity = new JSONObject(); + // 设置任务名称,调用getName方法获取 entity.put(GTaskStringUtils.GTASK_JSON_NAME, getName()); + // 设置创建者ID为"null",具体含义可能根据业务逻辑确定 entity.put(GTaskStringUtils.GTASK_JSON_CREATOR_ID, "null"); + // 设置实体类型为任务类型,使用GTaskStringUtils中定义的常量 entity.put(GTaskStringUtils.GTASK_JSON_ENTITY_TYPE, GTaskStringUtils.GTASK_JSON_TYPE_TASK); - if (getNotes() != null) { + // 如果任务备注信息不为空,则将备注信息添加到entity对象中 + if (getNotes()!= null) { entity.put(GTaskStringUtils.GTASK_JSON_NOTES, getNotes()); } + // 将任务实体信息对象添加到总的操作对象js中,对应字段为entity_delta js.put(GTaskStringUtils.GTASK_JSON_ENTITY_DELTA, entity); - // parent_id + // 设置父任务ID,通过父任务列表获取其Gid js.put(GTaskStringUtils.GTASK_JSON_PARENT_ID, mParent.getGid()); - // dest_parent_type + // 设置目标父类型为分组类型,使用GTaskStringUtils中定义的常量 js.put(GTaskStringUtils.GTASK_JSON_DEST_PARENT_TYPE, GTaskStringUtils.GTASK_JSON_TYPE_GROUP); - // list_id + // 设置列表ID,通过父任务列表获取其Gid js.put(GTaskStringUtils.GTASK_JSON_LIST_ID, mParent.getGid()); - // prior_sibling_id - if (mPriorSibling != null) { + // 如果存在前一个兄弟任务,则设置前一个兄弟任务的ID,通过前一个兄弟任务获取其Gid + if (mPriorSibling!= null) { js.put(GTaskStringUtils.GTASK_JSON_PRIOR_SIBLING_ID, mPriorSibling.getGid()); } } catch (JSONException e) { + // 如果出现JSON解析异常,记录错误日志,打印堆栈信息,并抛出一个操作失败异常 Log.e(TAG, e.toString()); e.printStackTrace(); throw new ActionFailureException("fail to generate task-create jsonobject"); @@ -103,30 +96,36 @@ public class Task extends Node { return js; } + // 根据给定的actionId创建一个用于表示更新任务操作的JSONObject对象 public JSONObject getUpdateAction(int actionId) { JSONObject js = new JSONObject(); try { - // action_type + // 设置action_type字段,表示操作类型为更新任务,使用GTaskStringUtils中定义的常量 js.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE, GTaskStringUtils.GTASK_JSON_ACTION_TYPE_UPDATE); - // action_id + // 设置action_id字段,传入给定的actionId js.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, actionId); - // id + // 设置id字段,通过调用getGid方法获取任务的唯一标识符 js.put(GTaskStringUtils.GTASK_JSON_ID, getGid()); - // entity_delta + // 创建一个表示任务实体信息更新内容的JSONObject对象 JSONObject entity = new JSONObject(); + // 设置任务名称,调用getName方法获取 entity.put(GTaskStringUtils.GTASK_JSON_NAME, getName()); - if (getNotes() != null) { + // 如果任务备注信息不为空,则将备注信息添加到entity对象中 + if (getNotes()!= null) { entity.put(GTaskStringUtils.GTASK_JSON_NOTES, getNotes()); } + // 设置任务是否已删除的状态,调用getDeleted方法获取(此处未看到其定义,推测是Task或其父类的方法) entity.put(GTaskStringUtils.GTASK_JSON_DELETED, getDeleted()); + // 将任务实体信息更新对象添加到总的操作对象js中,对应字段为entity_delta js.put(GTaskStringUtils.GTASK_JSON_ENTITY_DELTA, entity); } catch (JSONException e) { + // 如果出现JSON解析异常,记录错误日志,打印堆栈信息,并抛出一个操作失败异常 Log.e(TAG, e.toString()); e.printStackTrace(); throw new ActionFailureException("fail to generate task-update jsonobject"); @@ -135,39 +134,41 @@ public class Task extends Node { return js; } + // 根据远程传来的JSONObject对象设置任务的内容信息 public void setContentByRemoteJSON(JSONObject js) { - if (js != null) { + if (js!= null) { try { - // id + // 如果JSON对象中包含id字段,则设置任务的唯一标识符,通过getString方法获取对应的值 if (js.has(GTaskStringUtils.GTASK_JSON_ID)) { setGid(js.getString(GTaskStringUtils.GTASK_JSON_ID)); } - // last_modified + // 如果JSON对象中包含last_modified字段,则设置任务的最后修改时间,通过getLong方法获取对应的值 if (js.has(GTaskStringUtils.GTASK_JSON_LAST_MODIFIED)) { setLastModified(js.getLong(GTaskStringUtils.GTASK_JSON_LAST_MODIFIED)); } - // name + // 如果JSON对象中包含name字段,则设置任务的名称,通过getString方法获取对应的值 if (js.has(GTaskStringUtils.GTASK_JSON_NAME)) { setName(js.getString(GTaskStringUtils.GTASK_JSON_NAME)); } - // notes + // 如果JSON对象中包含notes字段,则设置任务的备注信息,通过getString方法获取对应的值 if (js.has(GTaskStringUtils.GTASK_JSON_NOTES)) { setNotes(js.getString(GTaskStringUtils.GTASK_JSON_NOTES)); } - // deleted + // 如果JSON对象中包含deleted字段,则设置任务是否已删除的状态,通过getBoolean方法获取对应的值 if (js.has(GTaskStringUtils.GTASK_JSON_DELETED)) { setDeleted(js.getBoolean(GTaskStringUtils.GTASK_JSON_DELETED)); } - // completed + // 如果JSON对象中包含completed字段,则设置任务是否已完成的状态,通过getBoolean方法获取对应的值 if (js.has(GTaskStringUtils.GTASK_JSON_COMPLETED)) { setCompleted(js.getBoolean(GTaskStringUtils.GTASK_JSON_COMPLETED)); } } catch (JSONException e) { + // 如果出现JSON解析异常,记录错误日志,打印堆栈信息,并抛出一个操作失败异常 Log.e(TAG, e.toString()); e.printStackTrace(); throw new ActionFailureException("fail to get task content from jsonobject"); @@ -175,40 +176,51 @@ public class Task extends Node { } } + // 根据本地的JSONObject对象设置任务的内容信息 public void setContentByLocalJSON(JSONObject js) { - if (js == null || !js.has(GTaskStringUtils.META_HEAD_NOTE) - || !js.has(GTaskStringUtils.META_HEAD_DATA)) { + // 如果传入的JSON对象为空,或者不包含关键的元数据头信息,则记录一个警告日志并返回 + if (js == null ||!js.has(GTaskStringUtils.META_HEAD_NOTE) + ||!js.has(GTaskStringUtils.META_HEAD_DATA)) { Log.w(TAG, "setContentByLocalJSON: nothing is avaiable"); } try { + // 获取JSON对象中的note相关信息的JSONObject对象 JSONObject note = js.getJSONObject(GTaskStringUtils.META_HEAD_NOTE); + // 获取JSON对象中的data数组信息的JSONArray对象 JSONArray dataArray = js.getJSONArray(GTaskStringUtils.META_HEAD_DATA); - if (note.getInt(NoteColumns.TYPE) != Notes.TYPE_NOTE) { + // 如果note的类型不是预期的笔记类型(此处Notes.TYPE_NOTE具体含义由业务逻辑确定),记录错误日志并返回 + if (note.getInt(NoteColumns.TYPE)!= Notes.TYPE_NOTE) { Log.e(TAG, "invalid type"); return; } + // 遍历data数组 for (int i = 0; i < dataArray.length(); i++) { JSONObject data = dataArray.getJSONObject(i); + // 如果数据的MIME类型匹配预期的笔记类型(DataConstants.NOTE具体含义由业务逻辑确定) if (TextUtils.equals(data.getString(DataColumns.MIME_TYPE), DataConstants.NOTE)) { + // 设置任务的名称为对应的数据内容 setName(data.getString(DataColumns.CONTENT)); break; } } } catch (JSONException e) { + // 如果出现JSON解析异常,记录错误日志并打印堆栈信息 Log.e(TAG, e.toString()); e.printStackTrace(); } } + // 根据任务当前的内容生成对应的本地JSONObject表示,用于存储或传输本地任务相关信息 public JSONObject getLocalJSONFromContent() { String name = getName(); try { + // 如果任务的元信息为空,可能表示是新从网络创建的任务 if (mMetaInfo == null) { - // new task created from web + // 如果任务名称为空,记录一个警告日志并返回null,表示这个任务可能为空任务 if (name == null) { Log.w(TAG, "the note seems to be an empty one"); return null; @@ -218,37 +230,46 @@ public class Task extends Node { JSONObject note = new JSONObject(); JSONArray dataArray = new JSONArray(); JSONObject data = new JSONObject(); + // 设置数据内容为任务名称 data.put(DataColumns.CONTENT, name); dataArray.put(data); + // 将数据数组添加到总的JSON对象中,对应字段为META_HEAD_DATA js.put(GTaskStringUtils.META_HEAD_DATA, dataArray); + // 设置note的类型为笔记类型(Notes.TYPE_NOTE具体含义由业务逻辑确定) note.put(NoteColumns.TYPE, Notes.TYPE_NOTE); + // 将note对象添加到总的JSON对象中,对应字段为META_HEAD_NOTE js.put(GTaskStringUtils.META_HEAD_NOTE, note); return js; } else { - // synced task + // 如果任务有元信息,表示是已同步过的任务 JSONObject note = mMetaInfo.getJSONObject(GTaskStringUtils.META_HEAD_NOTE); JSONArray dataArray = mMetaInfo.getJSONArray(GTaskStringUtils.META_HEAD_DATA); + // 遍历数据数组,查找匹配的笔记类型的数据 for (int i = 0; i < dataArray.length(); i++) { JSONObject data = dataArray.getJSONObject(i); if (TextUtils.equals(data.getString(DataColumns.MIME_TYPE), DataConstants.NOTE)) { + // 设置对应的数据内容为任务当前名称 data.put(DataColumns.CONTENT, getName()); break; } } + // 设置note的类型为笔记类型(Notes.TYPE_NOTE具体含义由业务逻辑确定) note.put(NoteColumns.TYPE, Notes.TYPE_NOTE); return mMetaInfo; } } catch (JSONException e) { + // 如果出现JSON解析异常,记录错误日志并打印堆栈信息,返回null Log.e(TAG, e.toString()); e.printStackTrace(); return null; } } + // 设置任务的元信息,从传入的MetaData对象中获取并解析其包含的笔记信息(如果有)来设置mMetaInfo public void setMetaInfo(MetaData metaData) { - if (metaData != null && metaData.getNotes() != null) { + if (metaData!= null && metaData.getNotes()!= null) { try { mMetaInfo = new JSONObject(metaData.getNotes()); } catch (JSONException e) { @@ -258,46 +279,50 @@ public class Task extends Node { } } + // 根据传入的Cursor(可能是数据库查询结果游标)确定任务的同步操作类型,比如是否需要更新本地、远程等情况 public int getSyncAction(Cursor c) { try { JSONObject noteInfo = null; - if (mMetaInfo != null && mMetaInfo.has(GTaskStringUtils.META_HEAD_NOTE)) { + // 如果任务有元信息并且包含关键的note信息,则获取对应的JSONObject对象 + if (mMetaInfo!= null && mMetaInfo.has(GTaskStringUtils.META_HEAD_NOTE)) { noteInfo = mMetaInfo.getJSONObject(GTaskStringUtils.META_HEAD_NOTE); } + // 如果note信息为空,记录一个警告日志,并表示需要更新远程(可能本地有变化但远程对应信息丢失了之类情况) if (noteInfo == null) { Log.w(TAG, "it seems that note meta has been deleted"); return SYNC_ACTION_UPDATE_REMOTE; } + // 如果note信息中不包含ID字段,记录一个警告日志,并表示需要更新本地(可能远程ID信息缺失等情况) if (!noteInfo.has(NoteColumns.ID)) { Log.w(TAG, "remote note id seems to be deleted"); return SYNC_ACTION_UPDATE_LOCAL; } - // validate the note id now - if (c.getLong(SqlNote.ID_COLUMN) != noteInfo.getLong(NoteColumns.ID)) { + // 验证note的ID是否匹配,不匹配则记录警告日志并表示需要更新本地 + if (c.getLong(SqlNote.ID_COLUMN)!= noteInfo.getLong(NoteColumns.ID)) { Log.w(TAG, "note id doesn't match"); return SYNC_ACTION_UPDATE_LOCAL; } + // 如果本地没有更新(本地修改时间为0) if (c.getInt(SqlNote.LOCAL_MODIFIED_COLUMN) == 0) { - // there is no local update + // 如果同步ID和任务最后修改时间相等,表示两边都没有更新 if (c.getLong(SqlNote.SYNC_ID_COLUMN) == getLastModified()) { - // no update both side return SYNC_ACTION_NONE; } else { - // apply remote to local + // 如果同步ID和任务最后修改时间不相等,表示需要将远程应用到本地 return SYNC_ACTION_UPDATE_LOCAL; } } else { - // validate gtask id + // 验证gtask的ID是否匹配,不匹配则记录错误日志并返回错误类型 if (!c.getString(SqlNote.GTASK_ID_COLUMN).equals(getGid())) { Log.e(TAG, "gtask id doesn't match"); return SYNC_ACTION_ERROR; } + // 如果同步ID和任务最后修改时间相等,表示只有本地有修改,需要更新远程 if (c.getLong(SqlNote.SYNC_ID_COLUMN) == getLastModified()) { - // local modification only return SYNC_ACTION_UPDATE_REMOTE; } else { return SYNC_ACTION_UPDATE_CONFLICT; @@ -311,41 +336,50 @@ public class Task extends Node { return SYNC_ACTION_ERROR; } + // 判断任务是否值得保存,根据是否有元信息、任务名称是否有效、备注信息是否有效等来综合判断 public boolean isWorthSaving() { - return mMetaInfo != null || (getName() != null && getName().trim().length() > 0) - || (getNotes() != null && getNotes().trim().length() > 0); + return mMetaInfo!= null || (getName()!= null && getName().trim().length() > 0) + || (getNotes()!= null && getNotes().trim().length() > 0); } + // 设置任务是否已完成的状态 public void setCompleted(boolean completed) { this.mCompleted = completed; } + // 设置任务的备注信息 public void setNotes(String notes) { this.mNotes = notes; } + // 设置任务的前一个兄弟任务 public void setPriorSibling(Task priorSibling) { this.mPriorSibling = priorSibling; } + // 设置任务所属的父任务列表 public void setParent(TaskList parent) { this.mParent = parent; } + // 获取任务是否已完成的状态并返回 public boolean getCompleted() { return this.mCompleted; } + // 获取任务的备注信息并返回 public String getNotes() { return this.mNotes; } + // 获取任务的前一个兄弟任务并返回 public Task getPriorSibling() { return this.mPriorSibling; } + // 获取任务所属的父任务列表并返回 public TaskList getParent() { return this.mParent; } -} +} \ No newline at end of file