|  |  |  | @ -0,0 +1,97 @@ | 
			
		
	
		
			
				
					|  |  |  |  | /* | 
			
		
	
		
			
				
					|  |  |  |  |  * 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类,从命名来看可能是用于处理与任务相关的元数据信息,比如关联的特定标识等
 | 
			
		
	
		
			
				
					|  |  |  |  | public class MetaData extends Task { | 
			
		
	
		
			
				
					|  |  |  |  |     // 定义一个用于日志记录的标签,使用类的简单名称(即不包含包名的类名),方便在查看日志时识别该类相关的输出信息
 | 
			
		
	
		
			
				
					|  |  |  |  |     private final static String TAG = MetaData.class.getSimpleName(); | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // 用于存储相关的GID(可能是某种全局唯一标识符,具体取决于业务逻辑),初始化为null
 | 
			
		
	
		
			
				
					|  |  |  |  |     private String mRelatedGid = null; | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // 设置元数据的方法,接收一个GID(可能用于关联其他对象或任务)和一个JSON对象(包含具体的元数据信息)作为参数
 | 
			
		
	
		
			
				
					|  |  |  |  |     public void setMeta(String gid, JSONObject metaInfo) { | 
			
		
	
		
			
				
					|  |  |  |  |         try { | 
			
		
	
		
			
				
					|  |  |  |  |             // 尝试将给定的GID放入JSON对象中,对应的键由GTaskStringUtils.META_HEAD_GTASK_ID指定,可能用于标记该元数据关联的具体任务ID
 | 
			
		
	
		
			
				
					|  |  |  |  |             metaInfo.put(GTaskStringUtils.META_HEAD_GTASK_ID, gid); | 
			
		
	
		
			
				
					|  |  |  |  |         } catch (JSONException e) { | 
			
		
	
		
			
				
					|  |  |  |  |             // 如果在向JSON对象中放入数据时出现异常,记录错误日志,提示设置相关GID失败
 | 
			
		
	
		
			
				
					|  |  |  |  |             Log.e(TAG, "failed to put related gid"); | 
			
		
	
		
			
				
					|  |  |  |  |         } | 
			
		
	
		
			
				
					|  |  |  |  |         // 将处理后的JSON对象转换为字符串,并设置为该对象的笔记内容(这里假设Task类中有对应的setNotes方法用于设置笔记相关内容)
 | 
			
		
	
		
			
				
					|  |  |  |  |         setNotes(metaInfo.toString()); | 
			
		
	
		
			
				
					|  |  |  |  |         // 设置该对象的名称,名称由GTaskStringUtils.META_NOTE_NAME指定,可能是一个固定的用于标识元数据类型的名称
 | 
			
		
	
		
			
				
					|  |  |  |  |         setName(GTaskStringUtils.META_NOTE_NAME); | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // 获取关联的GID的方法,外部可以通过调用此方法获取之前设置的相关标识符
 | 
			
		
	
		
			
				
					|  |  |  |  |     public String getRelatedGid() { | 
			
		
	
		
			
				
					|  |  |  |  |         return mRelatedGid; | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // 重写自Task类的方法,用于判断该元数据对象是否值得保存,这里的判断依据是看其笔记内容是否为null,若不为null则认为值得保存
 | 
			
		
	
		
			
				
					|  |  |  |  |     @Override | 
			
		
	
		
			
				
					|  |  |  |  |     public boolean isWorthSaving() { | 
			
		
	
		
			
				
					|  |  |  |  |         return getNotes()!= null; | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // 重写自Task类的方法,用于根据远程的JSON数据设置该对象的内容,并在这个过程中提取相关的GID信息
 | 
			
		
	
		
			
				
					|  |  |  |  |     @Override | 
			
		
	
		
			
				
					|  |  |  |  |     public void setContentByRemoteJSON(JSONObject js) { | 
			
		
	
		
			
				
					|  |  |  |  |         super.setContentByRemoteJSON(js); | 
			
		
	
		
			
				
					|  |  |  |  |         if (getNotes()!= null) { | 
			
		
	
		
			
				
					|  |  |  |  |             try { | 
			
		
	
		
			
				
					|  |  |  |  |                 // 将获取到的笔记内容字符串转换为JSON对象,以便从中提取相关信息
 | 
			
		
	
		
			
				
					|  |  |  |  |                 JSONObject metaInfo = new JSONObject(getNotes().trim()); | 
			
		
	
		
			
				
					|  |  |  |  |                 // 从JSON对象中获取关联的GID字符串,并赋值给成员变量mRelatedGid
 | 
			
		
	
		
			
				
					|  |  |  |  |                 mRelatedGid = metaInfo.getString(GTaskStringUtils.META_HEAD_GTASK_ID); | 
			
		
	
		
			
				
					|  |  |  |  |             } catch (JSONException e) { | 
			
		
	
		
			
				
					|  |  |  |  |                 // 如果在解析JSON获取GID时出现异常,记录警告日志,并将mRelatedGid设置为null
 | 
			
		
	
		
			
				
					|  |  |  |  |                 Log.w(TAG, "failed to get related gid"); | 
			
		
	
		
			
				
					|  |  |  |  |                 mRelatedGid = null; | 
			
		
	
		
			
				
					|  |  |  |  |             } | 
			
		
	
		
			
				
					|  |  |  |  |         } | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // 重写自Task类的方法,这里明确抛出异常表示该方法不应该被调用,可能在业务逻辑中该类对于通过本地JSON设置内容的操作是不支持的
 | 
			
		
	
		
			
				
					|  |  |  |  |     @Override | 
			
		
	
		
			
				
					|  |  |  |  |     public void setContentByLocalJSON(JSONObject js) { | 
			
		
	
		
			
				
					|  |  |  |  |         // this function should not be called
 | 
			
		
	
		
			
				
					|  |  |  |  |         throw new IllegalAccessError("MetaData:setContentByLocalJSON should not be called"); | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // 重写自Task类的方法,同样抛出异常表示该方法不应该被调用,可能该类不需要从内容生成本地JSON这种操作,或者这种操作不符合其业务逻辑
 | 
			
		
	
		
			
				
					|  |  |  |  |     @Override | 
			
		
	
		
			
				
					|  |  |  |  |     public JSONObject getLocalJSONFromContent() { | 
			
		
	
		
			
				
					|  |  |  |  |         throw new IllegalAccessError("MetaData:getLocalJSONFromContent should not be called"); | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // 重写自Task类的方法,再次抛出异常表示该方法不应该被调用,可能在数据同步相关的操作中,该类不需要执行获取同步动作的这个逻辑,具体取决于整体的业务设计
 | 
			
		
	
		
			
				
					|  |  |  |  |     @Override | 
			
		
	
		
			
				
					|  |  |  |  |     public int getSyncAction(Cursor c) { | 
			
		
	
		
			
				
					|  |  |  |  |         throw new IllegalAccessError("MetaData:getSyncAction should not be called"); | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | } |