/* * 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.util.Log; import net.micode.notes.tool.GTaskStringUtils; import org.json.JSONException; import org.json.JSONObject; /** * MetaData类是Task的子类,用于存储与Google Tasks同步相关的元数据信息。 *
* 该类主要用于在GTask同步过程中存储任务的关联信息,将元数据以JSON格式存储在 * Task的notes字段中,并提供了相应的解析和访问方法。 *
*/ public class MetaData extends Task { private final static String TAG = MetaData.class.getSimpleName(); /** * 与当前元数据相关联的Google Task ID */ private String mRelatedGid = null; /** * 设置元数据信息 ** 将Google Task ID添加到元数据JSON对象中,并将其存储在Task的notes字段中。 * 同时设置任务名称为元数据标识名称。 *
* * @param gid 与元数据关联的Google Task ID * @param metaInfo 包含元数据信息的JSON对象 */ public void setMeta(String gid, JSONObject metaInfo) { try { // 将关联的Google Task ID添加到元数据中 metaInfo.put(GTaskStringUtils.META_HEAD_GTASK_ID, gid); } catch (JSONException e) { Log.e(TAG, "failed to put related gid"); } // 将元数据JSON对象转换为字符串并存储在notes字段中 setNotes(metaInfo.toString()); // 设置任务名称为元数据标识名称 setName(GTaskStringUtils.META_NOTE_NAME); } /** * 获取与当前元数据相关联的Google Task ID * * @return 关联的Google Task ID,如果没有则返回null */ public String getRelatedGid() { return mRelatedGid; } /** * 判断当前元数据是否值得保存 ** 只有当notes字段不为null时,元数据才值得保存 *
* * @return 如果notes字段不为null则返回true,否则返回false */ @Override public boolean isWorthSaving() { return getNotes() != null; } /** * 从远程JSON数据设置内容 ** 从远程获取的JSON数据中解析元信息,并提取关联的Google Task ID *
* * @param js 包含远程数据的JSON对象 */ @Override public void setContentByRemoteJSON(JSONObject js) { // 调用父类方法设置基本内容 super.setContentByRemoteJSON(js); // 如果notes字段不为null,则解析元数据 if (getNotes() != null) { try { // 解析notes字段中的JSON元数据 JSONObject metaInfo = new JSONObject(getNotes().trim()); // 提取关联的Google Task ID mRelatedGid = metaInfo.getString(GTaskStringUtils.META_HEAD_GTASK_ID); } catch (JSONException e) { Log.w(TAG, "failed to get related gid"); mRelatedGid = null; } } } /** * 从本地JSON数据设置内容(不支持) ** 该方法不应该被调用,因为MetaData主要用于处理远程同步数据 *
* * @param js 本地JSON对象 * @throws IllegalAccessError 总是抛出此异常,表示该方法不应该被调用 */ @Override public void setContentByLocalJSON(JSONObject js) { // 此方法不应该被调用 throw new IllegalAccessError("MetaData:setContentByLocalJSON should not be called"); } /** * 从内容获取本地JSON数据(不支持) ** 该方法不应该被调用,因为MetaData主要用于处理远程同步数据 *
* * @return 本地JSON对象 * @throws IllegalAccessError 总是抛出此异常,表示该方法不应该被调用 */ @Override public JSONObject getLocalJSONFromContent() { throw new IllegalAccessError("MetaData:getLocalJSONFromContent should not be called"); } /** * 获取同步操作(不支持) ** 该方法不应该被调用,因为MetaData主要用于处理远程同步数据 *
* * @param c 本地数据库游标 * @return 同步操作类型 * @throws IllegalAccessError 总是抛出此异常,表示该方法不应该被调用 */ @Override public int getSyncAction(Cursor c) { throw new IllegalAccessError("MetaData:getSyncAction should not be called"); } }