mirror of
				https://github.com/commons-app/apps-android-commons.git
				synced 2025-10-26 12:23:58 +01:00 
			
		
		
		
	Make DbOpenHelper a singleton class accessible from different content providers
This commit is contained in:
		
							parent
							
								
									de93330970
								
							
						
					
					
						commit
						d8f85e22da
					
				
					 5 changed files with 12 additions and 14 deletions
				
			
		|  | @ -45,7 +45,6 @@ import com.android.volley.toolbox.*; | |||
| ) | ||||
| public class CommonsApplication extends Application { | ||||
| 
 | ||||
|     private DBOpenHelper dbOpenHelper; | ||||
|     public static String APPLICATION_VERSION; // Populated in onCreate. Race conditions theoretically possible, but practically not? | ||||
| 
 | ||||
|     private MWApi api; | ||||
|  | @ -87,15 +86,6 @@ public class CommonsApplication extends Application { | |||
|         return new MWApi(API_URL, createHttpClient()); | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|     public DBOpenHelper getDbOpenHelper() { | ||||
|         if(dbOpenHelper == null) { | ||||
|             dbOpenHelper = new DBOpenHelper(this); | ||||
|         } | ||||
|         return dbOpenHelper; | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|     @Override | ||||
|     public void onCreate() { | ||||
|         ACRA.init(this); | ||||
|  |  | |||
|  | @ -37,7 +37,7 @@ public class CategoryContentProvider extends ContentProvider { | |||
|     private DBOpenHelper dbOpenHelper; | ||||
|     @Override | ||||
|     public boolean onCreate() { | ||||
|         dbOpenHelper = ((CommonsApplication)this.getContext().getApplicationContext()).getDbOpenHelper(); | ||||
|         dbOpenHelper = DBOpenHelper.getInstance(getContext()); | ||||
|         return false; | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
|  | @ -34,7 +34,7 @@ public class ContributionsContentProvider extends ContentProvider{ | |||
|     private DBOpenHelper dbOpenHelper; | ||||
|     @Override | ||||
|     public boolean onCreate() { | ||||
|         dbOpenHelper = ((CommonsApplication)this.getContext().getApplicationContext()).getDbOpenHelper(); | ||||
|         dbOpenHelper = DBOpenHelper.getInstance(getContext()); | ||||
|         return false; | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
|  | @ -11,8 +11,16 @@ public class DBOpenHelper  extends SQLiteOpenHelper{ | |||
| 
 | ||||
|     private static final String DATABASE_NAME = "commons.db"; | ||||
|     private static final int DATABASE_VERSION = 6; | ||||
|     private static DBOpenHelper singleton = null; | ||||
| 
 | ||||
|     public DBOpenHelper(Context context) { | ||||
|     public static synchronized DBOpenHelper getInstance(Context context) { | ||||
|         if ( singleton == null ) { | ||||
|             singleton = new DBOpenHelper(context); | ||||
|         } | ||||
|         return singleton; | ||||
|     } | ||||
| 
 | ||||
|     private DBOpenHelper(Context context) { | ||||
|         super(context, DATABASE_NAME, null, DATABASE_VERSION); | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
|  | @ -34,7 +34,7 @@ public class ModificationsContentProvider extends ContentProvider{ | |||
|     private DBOpenHelper dbOpenHelper; | ||||
|     @Override | ||||
|     public boolean onCreate() { | ||||
|         dbOpenHelper = ((CommonsApplication)this.getContext().getApplicationContext()).getDbOpenHelper(); | ||||
|         dbOpenHelper = DBOpenHelper.getInstance(getContext()); | ||||
|         return false; | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Yusuke Matsubara
						Yusuke Matsubara