Android: Expose a proper interface for C++ IniFile class
Replaces the inflexible INI functions in NativeLibrary.
This commit is contained in:
parent
c8c4ec28ce
commit
74f197caed
|
@ -274,43 +274,6 @@ public final class NativeLibrary
|
||||||
// Angle is in radians and should be non-negative
|
// Angle is in radians and should be non-negative
|
||||||
public static native double GetInputRadiusAtAngle(int emu_pad_id, int stick, double angle);
|
public static native double GetInputRadiusAtAngle(int emu_pad_id, int stick, double angle);
|
||||||
|
|
||||||
public static native void NewGameIniFile();
|
|
||||||
|
|
||||||
public static native void LoadGameIniFile(String gameId);
|
|
||||||
|
|
||||||
public static native void SaveGameIniFile(String gameId);
|
|
||||||
|
|
||||||
public static native String GetUserSetting(String gameID, String Section, String Key);
|
|
||||||
|
|
||||||
public static native void SetUserSetting(String gameID, String Section, String Key, String Value);
|
|
||||||
|
|
||||||
public static native void SetProfileSetting(String profile, String Section, String Key,
|
|
||||||
String Value);
|
|
||||||
|
|
||||||
public static native void InitGameIni(String gameID);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets a value from a key in the given ini-based config file.
|
|
||||||
*
|
|
||||||
* @param configFile The ini-based config file to get the value from.
|
|
||||||
* @param Section The section key that the actual key is in.
|
|
||||||
* @param Key The key to get the value from.
|
|
||||||
* @param Default The value to return in the event the given key doesn't exist.
|
|
||||||
* @return the value stored at the key, or a default value if it doesn't exist.
|
|
||||||
*/
|
|
||||||
public static native String GetConfig(String configFile, String Section, String Key,
|
|
||||||
String Default);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Sets a value to a key in the given ini config file.
|
|
||||||
*
|
|
||||||
* @param configFile The ini-based config file to add the value to.
|
|
||||||
* @param Section The section key for the ini key
|
|
||||||
* @param Key The actual ini key to set.
|
|
||||||
* @param Value The string to set the ini key to.
|
|
||||||
*/
|
|
||||||
public static native void SetConfig(String configFile, String Section, String Key, String Value);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the Dolphin version string.
|
* Gets the Dolphin version string.
|
||||||
*
|
*
|
||||||
|
|
|
@ -47,10 +47,12 @@ import org.dolphinemu.dolphinemu.ui.main.TvMainActivity;
|
||||||
import org.dolphinemu.dolphinemu.ui.platform.Platform;
|
import org.dolphinemu.dolphinemu.ui.platform.Platform;
|
||||||
import org.dolphinemu.dolphinemu.utils.ControllerMappingHelper;
|
import org.dolphinemu.dolphinemu.utils.ControllerMappingHelper;
|
||||||
import org.dolphinemu.dolphinemu.utils.FileBrowserHelper;
|
import org.dolphinemu.dolphinemu.utils.FileBrowserHelper;
|
||||||
|
import org.dolphinemu.dolphinemu.utils.IniFile;
|
||||||
import org.dolphinemu.dolphinemu.utils.MotionListener;
|
import org.dolphinemu.dolphinemu.utils.MotionListener;
|
||||||
import org.dolphinemu.dolphinemu.utils.Rumble;
|
import org.dolphinemu.dolphinemu.utils.Rumble;
|
||||||
import org.dolphinemu.dolphinemu.utils.TvUtil;
|
import org.dolphinemu.dolphinemu.utils.TvUtil;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
import java.lang.annotation.Retention;
|
import java.lang.annotation.Retention;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
@ -962,10 +964,14 @@ public final class EmulationActivity extends AppCompatActivity
|
||||||
(dialog, indexSelected) ->
|
(dialog, indexSelected) ->
|
||||||
{
|
{
|
||||||
editor.putInt("wiiController", indexSelected);
|
editor.putInt("wiiController", indexSelected);
|
||||||
NativeLibrary.SetConfig("WiimoteNew.ini", "Wiimote1", "Extension",
|
|
||||||
|
File wiimoteNewFile = SettingsFile.getSettingsFile(SettingsFile.FILE_NAME_WIIMOTE);
|
||||||
|
IniFile wiimoteNewIni = new IniFile(wiimoteNewFile);
|
||||||
|
wiimoteNewIni.setString("Wiimote1", "Extension",
|
||||||
getResources().getStringArray(R.array.controllersValues)[indexSelected]);
|
getResources().getStringArray(R.array.controllersValues)[indexSelected]);
|
||||||
NativeLibrary.SetConfig("WiimoteNew.ini", "Wiimote1",
|
wiimoteNewIni.setBoolean("Wiimote1", "Options/Sideways Wiimote", indexSelected == 2);
|
||||||
"Options/Sideways Wiimote", indexSelected == 2 ? "True" : "False");
|
wiimoteNewIni.save(wiimoteNewFile);
|
||||||
|
|
||||||
NativeLibrary.ReloadWiimoteConfig();
|
NativeLibrary.ReloadWiimoteConfig();
|
||||||
});
|
});
|
||||||
builder.setPositiveButton(getString(R.string.ok), (dialogInterface, i) ->
|
builder.setPositiveButton(getString(R.string.ok), (dialogInterface, i) ->
|
||||||
|
@ -994,8 +1000,11 @@ public final class EmulationActivity extends AppCompatActivity
|
||||||
else
|
else
|
||||||
mMotionListener.disable();
|
mMotionListener.disable();
|
||||||
|
|
||||||
NativeLibrary.SetConfig("WiimoteNew.ini", "Wiimote1", "IMUIR/Enabled",
|
File wiimoteNewFile = SettingsFile.getSettingsFile(SettingsFile.FILE_NAME_WIIMOTE);
|
||||||
indexSelected != 1 ? "True" : "False");
|
IniFile wiimoteNewIni = new IniFile(wiimoteNewFile);
|
||||||
|
wiimoteNewIni.setBoolean("Wiimote1", "IMUIR/Enabled", indexSelected != 1);
|
||||||
|
wiimoteNewIni.save(wiimoteNewFile);
|
||||||
|
|
||||||
NativeLibrary.ReloadWiimoteConfig();
|
NativeLibrary.ReloadWiimoteConfig();
|
||||||
});
|
});
|
||||||
builder.setPositiveButton(getString(R.string.ok), (dialogInterface, i) -> editor.apply());
|
builder.setPositiveButton(getString(R.string.ok), (dialogInterface, i) -> editor.apply());
|
||||||
|
@ -1137,15 +1146,15 @@ public final class EmulationActivity extends AppCompatActivity
|
||||||
builder.setView(view);
|
builder.setView(view);
|
||||||
builder.setPositiveButton(R.string.ok, (dialogInterface, i) ->
|
builder.setPositiveButton(R.string.ok, (dialogInterface, i) ->
|
||||||
{
|
{
|
||||||
NativeLibrary.LoadGameIniFile(mSelectedGameId);
|
File file = SettingsFile.getCustomGameSettingsFile(mSelectedGameId);
|
||||||
NativeLibrary.SetUserSetting(mSelectedGameId, Settings.SECTION_CONTROLS,
|
IniFile ini = new IniFile(file);
|
||||||
SettingsFile.KEY_WIIBIND_IR_PITCH, text_slider_value_pitch.getText().toString());
|
ini.setString(Settings.SECTION_CONTROLS, SettingsFile.KEY_WIIBIND_IR_PITCH,
|
||||||
NativeLibrary.SetUserSetting(mSelectedGameId, Settings.SECTION_CONTROLS,
|
text_slider_value_pitch.getText().toString());
|
||||||
SettingsFile.KEY_WIIBIND_IR_YAW, text_slider_value_yaw.getText().toString());
|
ini.setString(Settings.SECTION_CONTROLS, SettingsFile.KEY_WIIBIND_IR_YAW,
|
||||||
NativeLibrary.SetUserSetting(mSelectedGameId, Settings.SECTION_CONTROLS,
|
text_slider_value_yaw.getText().toString());
|
||||||
SettingsFile.KEY_WIIBIND_IR_VERTICAL_OFFSET,
|
ini.setString(Settings.SECTION_CONTROLS, SettingsFile.KEY_WIIBIND_IR_VERTICAL_OFFSET,
|
||||||
text_slider_value_vertical_offset.getText().toString());
|
text_slider_value_vertical_offset.getText().toString());
|
||||||
NativeLibrary.SaveGameIniFile(mSelectedGameId);
|
ini.save(file);
|
||||||
|
|
||||||
NativeLibrary.ReloadWiimoteConfig();
|
NativeLibrary.ReloadWiimoteConfig();
|
||||||
|
|
||||||
|
|
|
@ -16,6 +16,7 @@ import org.dolphinemu.dolphinemu.features.settings.ui.MenuTag;
|
||||||
import org.dolphinemu.dolphinemu.features.settings.ui.SettingsActivity;
|
import org.dolphinemu.dolphinemu.features.settings.ui.SettingsActivity;
|
||||||
import org.dolphinemu.dolphinemu.features.settings.utils.SettingsFile;
|
import org.dolphinemu.dolphinemu.features.settings.utils.SettingsFile;
|
||||||
import org.dolphinemu.dolphinemu.ui.platform.Platform;
|
import org.dolphinemu.dolphinemu.ui.platform.Platform;
|
||||||
|
import org.dolphinemu.dolphinemu.utils.IniFile;
|
||||||
import org.dolphinemu.dolphinemu.utils.DirectoryInitialization;
|
import org.dolphinemu.dolphinemu.utils.DirectoryInitialization;
|
||||||
import org.dolphinemu.dolphinemu.utils.Log;
|
import org.dolphinemu.dolphinemu.utils.Log;
|
||||||
|
|
||||||
|
@ -65,8 +66,12 @@ public class GamePropertiesDialog extends DialogFragment
|
||||||
.getSupportFragmentManager(), "game_details");
|
.getSupportFragmentManager(), "game_details");
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
NativeLibrary.SetConfig(SettingsFile.FILE_NAME_DOLPHIN + ".ini",
|
File dolphinFile = SettingsFile.getSettingsFile(SettingsFile.FILE_NAME_DOLPHIN);
|
||||||
Settings.SECTION_INI_CORE, SettingsFile.KEY_DEFAULT_ISO, path);
|
IniFile dolphinIni = new IniFile(dolphinFile);
|
||||||
|
dolphinIni.setString(Settings.SECTION_INI_CORE, SettingsFile.KEY_DEFAULT_ISO,
|
||||||
|
path);
|
||||||
|
dolphinIni.save(dolphinFile);
|
||||||
|
|
||||||
NativeLibrary.ReloadConfig();
|
NativeLibrary.ReloadConfig();
|
||||||
Toast.makeText(getContext(), "Default ISO set", Toast.LENGTH_SHORT).show();
|
Toast.makeText(getContext(), "Default ISO set", Toast.LENGTH_SHORT).show();
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -7,7 +7,9 @@ import org.dolphinemu.dolphinemu.NativeLibrary;
|
||||||
import org.dolphinemu.dolphinemu.features.settings.ui.SettingsActivityView;
|
import org.dolphinemu.dolphinemu.features.settings.ui.SettingsActivityView;
|
||||||
import org.dolphinemu.dolphinemu.features.settings.utils.SettingsFile;
|
import org.dolphinemu.dolphinemu.features.settings.utils.SettingsFile;
|
||||||
import org.dolphinemu.dolphinemu.services.GameFileCacheService;
|
import org.dolphinemu.dolphinemu.services.GameFileCacheService;
|
||||||
|
import org.dolphinemu.dolphinemu.utils.IniFile;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
@ -40,9 +42,9 @@ public class Settings
|
||||||
public static final String SECTION_CONTROLS = "Controls";
|
public static final String SECTION_CONTROLS = "Controls";
|
||||||
public static final String SECTION_PROFILE = "Profile";
|
public static final String SECTION_PROFILE = "Profile";
|
||||||
|
|
||||||
private static final String DSP_HLE = "0";
|
private static final int DSP_HLE = 0;
|
||||||
private static final String DSP_LLE_RECOMPILER = "1";
|
private static final int DSP_LLE_RECOMPILER = 1;
|
||||||
private static final String DSP_LLE_INTERPRETER = "2";
|
private static final int DSP_LLE_INTERPRETER = 2;
|
||||||
|
|
||||||
public static final String SECTION_ANALYTICS = "Analytics";
|
public static final String SECTION_ANALYTICS = "Analytics";
|
||||||
|
|
||||||
|
@ -195,37 +197,29 @@ public class Settings
|
||||||
|
|
||||||
if (modifiedSettings.contains(SettingsFile.KEY_DSP_ENGINE))
|
if (modifiedSettings.contains(SettingsFile.KEY_DSP_ENGINE))
|
||||||
{
|
{
|
||||||
switch (NativeLibrary
|
File dolphinFile = SettingsFile.getSettingsFile(SettingsFile.FILE_NAME_DOLPHIN);
|
||||||
.GetConfig(SettingsFile.FILE_NAME_DOLPHIN + ".ini", Settings.SECTION_INI_ANDROID,
|
IniFile dolphinIni = new IniFile(dolphinFile);
|
||||||
SettingsFile.KEY_DSP_ENGINE, DSP_HLE))
|
|
||||||
|
switch (dolphinIni.getInt(Settings.SECTION_INI_ANDROID, SettingsFile.KEY_DSP_ENGINE,
|
||||||
|
DSP_HLE))
|
||||||
{
|
{
|
||||||
case DSP_HLE:
|
case DSP_HLE:
|
||||||
NativeLibrary
|
dolphinIni.setBoolean(Settings.SECTION_INI_CORE, SettingsFile.KEY_DSP_HLE, true);
|
||||||
.SetConfig(SettingsFile.FILE_NAME_DOLPHIN + ".ini", Settings.SECTION_INI_CORE,
|
dolphinIni.setBoolean(Settings.SECTION_INI_DSP, SettingsFile.KEY_DSP_ENABLE_JIT, true);
|
||||||
SettingsFile.KEY_DSP_HLE, "True");
|
|
||||||
NativeLibrary
|
|
||||||
.SetConfig(SettingsFile.FILE_NAME_DOLPHIN + ".ini", Settings.SECTION_INI_DSP,
|
|
||||||
SettingsFile.KEY_DSP_ENABLE_JIT, "True");
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DSP_LLE_RECOMPILER:
|
case DSP_LLE_RECOMPILER:
|
||||||
NativeLibrary
|
dolphinIni.setBoolean(Settings.SECTION_INI_CORE, SettingsFile.KEY_DSP_HLE, false);
|
||||||
.SetConfig(SettingsFile.FILE_NAME_DOLPHIN + ".ini", Settings.SECTION_INI_CORE,
|
dolphinIni.setBoolean(Settings.SECTION_INI_DSP, SettingsFile.KEY_DSP_ENABLE_JIT, true);
|
||||||
SettingsFile.KEY_DSP_HLE, "False");
|
|
||||||
NativeLibrary
|
|
||||||
.SetConfig(SettingsFile.FILE_NAME_DOLPHIN + ".ini", Settings.SECTION_INI_DSP,
|
|
||||||
SettingsFile.KEY_DSP_ENABLE_JIT, "True");
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DSP_LLE_INTERPRETER:
|
case DSP_LLE_INTERPRETER:
|
||||||
NativeLibrary
|
dolphinIni.setBoolean(Settings.SECTION_INI_CORE, SettingsFile.KEY_DSP_HLE, false);
|
||||||
.SetConfig(SettingsFile.FILE_NAME_DOLPHIN + ".ini", Settings.SECTION_INI_CORE,
|
dolphinIni.setBoolean(Settings.SECTION_INI_DSP, SettingsFile.KEY_DSP_ENABLE_JIT, false);
|
||||||
SettingsFile.KEY_DSP_HLE, "False");
|
|
||||||
NativeLibrary
|
|
||||||
.SetConfig(SettingsFile.FILE_NAME_DOLPHIN + ".ini", Settings.SECTION_INI_DSP,
|
|
||||||
SettingsFile.KEY_DSP_ENABLE_JIT, "False");
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
dolphinIni.save(dolphinFile);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Notify the native code of the changes
|
// Notify the native code of the changes
|
||||||
|
|
|
@ -2,6 +2,9 @@ package org.dolphinemu.dolphinemu.features.settings.model.view;
|
||||||
|
|
||||||
import org.dolphinemu.dolphinemu.features.settings.model.Setting;
|
import org.dolphinemu.dolphinemu.features.settings.model.Setting;
|
||||||
import org.dolphinemu.dolphinemu.features.settings.model.StringSetting;
|
import org.dolphinemu.dolphinemu.features.settings.model.StringSetting;
|
||||||
|
import org.dolphinemu.dolphinemu.features.settings.utils.SettingsFile;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
|
||||||
public final class FilePicker extends SettingsItem
|
public final class FilePicker extends SettingsItem
|
||||||
{
|
{
|
||||||
|
@ -18,9 +21,9 @@ public final class FilePicker extends SettingsItem
|
||||||
mRequestType = requestType;
|
mRequestType = requestType;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getFile()
|
public File getFile()
|
||||||
{
|
{
|
||||||
return mFile + ".ini";
|
return SettingsFile.getSettingsFile(mFile);
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getSelectedValue()
|
public String getSelectedValue()
|
||||||
|
|
|
@ -43,6 +43,7 @@ import org.dolphinemu.dolphinemu.features.settings.ui.viewholder.SubmenuViewHold
|
||||||
import org.dolphinemu.dolphinemu.features.settings.utils.SettingsFile;
|
import org.dolphinemu.dolphinemu.features.settings.utils.SettingsFile;
|
||||||
import org.dolphinemu.dolphinemu.ui.main.MainPresenter;
|
import org.dolphinemu.dolphinemu.ui.main.MainPresenter;
|
||||||
import org.dolphinemu.dolphinemu.utils.FileBrowserHelper;
|
import org.dolphinemu.dolphinemu.utils.FileBrowserHelper;
|
||||||
|
import org.dolphinemu.dolphinemu.utils.IniFile;
|
||||||
|
|
||||||
import java.security.InvalidParameterException;
|
import java.security.InvalidParameterException;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
@ -319,8 +320,10 @@ public final class SettingsAdapter extends RecyclerView.Adapter<SettingViewHolde
|
||||||
{
|
{
|
||||||
FilePicker filePicker = (FilePicker) mClickedItem;
|
FilePicker filePicker = (FilePicker) mClickedItem;
|
||||||
|
|
||||||
NativeLibrary.SetConfig(filePicker.getFile(), filePicker.getSection(), filePicker.getKey(),
|
IniFile ini = new IniFile(filePicker.getFile());
|
||||||
file);
|
ini.setString(filePicker.getSection(), filePicker.getKey(), file);
|
||||||
|
ini.save(filePicker.getFile());
|
||||||
|
|
||||||
NativeLibrary.ReloadConfig();
|
NativeLibrary.ReloadConfig();
|
||||||
|
|
||||||
mClickedItem = null;
|
mClickedItem = null;
|
||||||
|
|
|
@ -3,12 +3,12 @@ package org.dolphinemu.dolphinemu.features.settings.ui.viewholder;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
import org.dolphinemu.dolphinemu.NativeLibrary;
|
|
||||||
import org.dolphinemu.dolphinemu.R;
|
import org.dolphinemu.dolphinemu.R;
|
||||||
import org.dolphinemu.dolphinemu.features.settings.model.view.FilePicker;
|
import org.dolphinemu.dolphinemu.features.settings.model.view.FilePicker;
|
||||||
import org.dolphinemu.dolphinemu.features.settings.model.view.SettingsItem;
|
import org.dolphinemu.dolphinemu.features.settings.model.view.SettingsItem;
|
||||||
import org.dolphinemu.dolphinemu.features.settings.ui.SettingsAdapter;
|
import org.dolphinemu.dolphinemu.features.settings.ui.SettingsAdapter;
|
||||||
import org.dolphinemu.dolphinemu.ui.main.MainPresenter;
|
import org.dolphinemu.dolphinemu.ui.main.MainPresenter;
|
||||||
|
import org.dolphinemu.dolphinemu.utils.IniFile;
|
||||||
|
|
||||||
public final class FilePickerViewHolder extends SettingViewHolder
|
public final class FilePickerViewHolder extends SettingViewHolder
|
||||||
{
|
{
|
||||||
|
@ -44,9 +44,10 @@ public final class FilePickerViewHolder extends SettingViewHolder
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
mTextSettingDescription.setText(NativeLibrary
|
// TODO: Reopening INI files all the time is slow
|
||||||
.GetConfig(mFilePicker.getFile(), item.getSection(), item.getKey(),
|
IniFile ini = new IniFile(mFilePicker.getFile());
|
||||||
mFilePicker.getSelectedValue()));
|
mTextSettingDescription.setText(ini.getString(item.getSection(), item.getKey(),
|
||||||
|
mFilePicker.getSelectedValue()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -15,6 +15,7 @@ import org.dolphinemu.dolphinemu.features.settings.model.StringSetting;
|
||||||
import org.dolphinemu.dolphinemu.features.settings.ui.SettingsActivityView;
|
import org.dolphinemu.dolphinemu.features.settings.ui.SettingsActivityView;
|
||||||
import org.dolphinemu.dolphinemu.utils.DirectoryInitialization;
|
import org.dolphinemu.dolphinemu.utils.DirectoryInitialization;
|
||||||
import org.dolphinemu.dolphinemu.utils.BiMap;
|
import org.dolphinemu.dolphinemu.utils.BiMap;
|
||||||
|
import org.dolphinemu.dolphinemu.utils.IniFile;
|
||||||
import org.dolphinemu.dolphinemu.utils.Log;
|
import org.dolphinemu.dolphinemu.utils.Log;
|
||||||
|
|
||||||
import java.io.BufferedReader;
|
import java.io.BufferedReader;
|
||||||
|
@ -464,7 +465,7 @@ public final class SettingsFile
|
||||||
{
|
{
|
||||||
Set<String> sortedSections = new TreeSet<>(sections.keySet());
|
Set<String> sortedSections = new TreeSet<>(sections.keySet());
|
||||||
|
|
||||||
NativeLibrary.NewGameIniFile();
|
IniFile ini = new IniFile();
|
||||||
for (String sectionKey : sortedSections)
|
for (String sectionKey : sortedSections)
|
||||||
{
|
{
|
||||||
SettingSection section = sections.get(sectionKey);
|
SettingSection section = sections.get(sectionKey);
|
||||||
|
@ -491,12 +492,12 @@ public final class SettingsFile
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
NativeLibrary.SetUserSetting(gameId, mapSectionNameFromIni(section.getName()),
|
ini.setString(mapSectionNameFromIni(section.getName()), setting.getKey(),
|
||||||
setting.getKey(), setting.getValueAsString());
|
setting.getValueAsString());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
NativeLibrary.SaveGameIniFile(gameId);
|
ini.save(getCustomGameSettingsFile(gameId));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -508,31 +509,40 @@ public final class SettingsFile
|
||||||
* @param padId
|
* @param padId
|
||||||
*/
|
*/
|
||||||
private static void saveCustomWiimoteSetting(final String gameId, final String key,
|
private static void saveCustomWiimoteSetting(final String gameId, final String key,
|
||||||
final String value,
|
final String value, final String padId)
|
||||||
final String padId)
|
|
||||||
{
|
{
|
||||||
String profile = gameId + "_Wii" + padId;
|
String profile = gameId + "_Wii" + padId;
|
||||||
String wiiConfigPath =
|
String wiiConfigPath =
|
||||||
DirectoryInitialization.getUserDirectory() + "/Config/Profiles/Wiimote/" +
|
DirectoryInitialization.getUserDirectory() + "/Config/Profiles/Wiimote/" +
|
||||||
profile + ".ini";
|
profile + ".ini";
|
||||||
File wiiProfile = new File(wiiConfigPath);
|
File wiiProfile = getWiiProfile(profile, padId);
|
||||||
// If it doesn't exist, create it
|
// If it doesn't exist, create it
|
||||||
if (!wiiProfile.exists())
|
boolean wiiProfileExists = wiiProfile.exists();
|
||||||
|
if (!wiiProfileExists)
|
||||||
{
|
{
|
||||||
String defautlWiiProfilePath =
|
String defautlWiiProfilePath =
|
||||||
DirectoryInitialization.getUserDirectory() +
|
DirectoryInitialization.getUserDirectory() +
|
||||||
"/Config/Profiles/Wiimote/WiimoteProfile.ini";
|
"/Config/Profiles/Wiimote/WiimoteProfile.ini";
|
||||||
DirectoryInitialization.copyFile(defautlWiiProfilePath, wiiConfigPath);
|
DirectoryInitialization.copyFile(defautlWiiProfilePath, wiiConfigPath);
|
||||||
|
}
|
||||||
|
|
||||||
NativeLibrary.SetProfileSetting(profile, Settings.SECTION_PROFILE, "Device",
|
IniFile wiiProfileIni = new IniFile(wiiConfigPath);
|
||||||
|
|
||||||
|
if (!wiiProfileExists)
|
||||||
|
{
|
||||||
|
wiiProfileIni.setString(Settings.SECTION_PROFILE, "Device",
|
||||||
"Android/" + (Integer.parseInt(padId) + 4) + "/Touchscreen");
|
"Android/" + (Integer.parseInt(padId) + 4) + "/Touchscreen");
|
||||||
}
|
}
|
||||||
|
|
||||||
NativeLibrary.SetProfileSetting(profile, Settings.SECTION_PROFILE, key, value);
|
wiiProfileIni.setString(Settings.SECTION_PROFILE, key, value);
|
||||||
|
wiiProfileIni.save(wiiConfigPath);
|
||||||
|
|
||||||
// Enable the profile
|
// Enable the profile
|
||||||
NativeLibrary.SetUserSetting(gameId, Settings.SECTION_CONTROLS,
|
File gameSettingsFile = SettingsFile.getCustomGameSettingsFile(gameId);
|
||||||
|
IniFile gameSettingsIni = new IniFile(gameSettingsFile);
|
||||||
|
gameSettingsIni.setString(Settings.SECTION_CONTROLS,
|
||||||
KEY_WIIMOTE_PROFILE + (Integer.parseInt(padId) + 1), profile);
|
KEY_WIIMOTE_PROFILE + (Integer.parseInt(padId) + 1), profile);
|
||||||
|
gameSettingsIni.save(gameSettingsFile);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static String mapSectionNameFromIni(String generalSectionName)
|
private static String mapSectionNameFromIni(String generalSectionName)
|
||||||
|
@ -556,7 +566,7 @@ public final class SettingsFile
|
||||||
}
|
}
|
||||||
|
|
||||||
@NonNull
|
@NonNull
|
||||||
private static File getSettingsFile(String fileName)
|
public static File getSettingsFile(String fileName)
|
||||||
{
|
{
|
||||||
return new File(
|
return new File(
|
||||||
DirectoryInitialization.getUserDirectory() + "/Config/" + fileName + ".ini");
|
DirectoryInitialization.getUserDirectory() + "/Config/" + fileName + ".ini");
|
||||||
|
@ -578,9 +588,8 @@ public final class SettingsFile
|
||||||
gameId + ".ini");
|
gameId + ".ini");
|
||||||
}
|
}
|
||||||
|
|
||||||
private static File getCustomGameSettingsFile(String gameId)
|
public static File getCustomGameSettingsFile(String gameId)
|
||||||
{
|
{
|
||||||
|
|
||||||
return new File(
|
return new File(
|
||||||
DirectoryInitialization.getUserDirectory() + "/GameSettings/" + gameId + ".ini");
|
DirectoryInitialization.getUserDirectory() + "/GameSettings/" + gameId + ".ini");
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,6 +7,7 @@ import android.preference.PreferenceManager;
|
||||||
import org.dolphinemu.dolphinemu.NativeLibrary;
|
import org.dolphinemu.dolphinemu.NativeLibrary;
|
||||||
import org.dolphinemu.dolphinemu.features.settings.model.Settings;
|
import org.dolphinemu.dolphinemu.features.settings.model.Settings;
|
||||||
import org.dolphinemu.dolphinemu.features.settings.utils.SettingsFile;
|
import org.dolphinemu.dolphinemu.features.settings.utils.SettingsFile;
|
||||||
|
import org.dolphinemu.dolphinemu.utils.IniFile;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
|
@ -82,9 +83,10 @@ public class GameFileCache
|
||||||
*/
|
*/
|
||||||
public boolean scanLibrary(Context context)
|
public boolean scanLibrary(Context context)
|
||||||
{
|
{
|
||||||
boolean recursiveScan = NativeLibrary
|
IniFile dolphinIni =
|
||||||
.GetConfig(SettingsFile.FILE_NAME_DOLPHIN + ".ini", Settings.SECTION_INI_GENERAL,
|
new IniFile(SettingsFile.getSettingsFile(SettingsFile.FILE_NAME_DOLPHIN));
|
||||||
SettingsFile.KEY_RECURSIVE_ISO_PATHS, "False").equals("True");
|
boolean recursiveScan = dolphinIni.getBoolean(Settings.SECTION_INI_GENERAL,
|
||||||
|
SettingsFile.KEY_RECURSIVE_ISO_PATHS, false);
|
||||||
|
|
||||||
removeNonExistentGameFolders(context);
|
removeNonExistentGameFolders(context);
|
||||||
|
|
||||||
|
|
|
@ -33,6 +33,7 @@ import org.dolphinemu.dolphinemu.R;
|
||||||
import org.dolphinemu.dolphinemu.activities.EmulationActivity;
|
import org.dolphinemu.dolphinemu.activities.EmulationActivity;
|
||||||
import org.dolphinemu.dolphinemu.features.settings.model.Settings;
|
import org.dolphinemu.dolphinemu.features.settings.model.Settings;
|
||||||
import org.dolphinemu.dolphinemu.features.settings.utils.SettingsFile;
|
import org.dolphinemu.dolphinemu.features.settings.utils.SettingsFile;
|
||||||
|
import org.dolphinemu.dolphinemu.utils.IniFile;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
|
@ -51,9 +52,9 @@ public final class InputOverlay extends SurfaceView implements OnTouchListener
|
||||||
public static final int OVERLAY_WIIMOTE_CLASSIC = 4;
|
public static final int OVERLAY_WIIMOTE_CLASSIC = 4;
|
||||||
public static final int OVERLAY_NONE = 5;
|
public static final int OVERLAY_NONE = 5;
|
||||||
|
|
||||||
private static final String DISABLED_GAMECUBE_CONTROLLER = "0";
|
private static final int DISABLED_GAMECUBE_CONTROLLER = 0;
|
||||||
private static final String EMULATED_GAMECUBE_CONTROLLER = "6";
|
private static final int EMULATED_GAMECUBE_CONTROLLER = 6;
|
||||||
private static final String GAMECUBE_ADAPTER = "12";
|
private static final int GAMECUBE_ADAPTER = 12;
|
||||||
|
|
||||||
private final Set<InputOverlayDrawableButton> overlayButtons = new HashSet<>();
|
private final Set<InputOverlayDrawableButton> overlayButtons = new HashSet<>();
|
||||||
private final Set<InputOverlayDrawableDpad> overlayDpads = new HashSet<>();
|
private final Set<InputOverlayDrawableDpad> overlayDpads = new HashSet<>();
|
||||||
|
@ -703,9 +704,11 @@ public final class InputOverlay extends SurfaceView implements OnTouchListener
|
||||||
// Add all the enabled overlay items back to the HashSet.
|
// Add all the enabled overlay items back to the HashSet.
|
||||||
if (EmulationActivity.isGameCubeGame())
|
if (EmulationActivity.isGameCubeGame())
|
||||||
{
|
{
|
||||||
switch (NativeLibrary
|
IniFile dolphinIni =
|
||||||
.GetConfig(SettingsFile.FILE_NAME_DOLPHIN + ".ini", Settings.SECTION_INI_CORE,
|
new IniFile(SettingsFile.getSettingsFile(SettingsFile.FILE_NAME_DOLPHIN));
|
||||||
SettingsFile.KEY_GCPAD_PLAYER_1, EMULATED_GAMECUBE_CONTROLLER))
|
|
||||||
|
switch (dolphinIni.getInt(Settings.SECTION_INI_CORE, SettingsFile.KEY_GCPAD_PLAYER_1,
|
||||||
|
EMULATED_GAMECUBE_CONTROLLER))
|
||||||
{
|
{
|
||||||
case DISABLED_GAMECUBE_CONTROLLER:
|
case DISABLED_GAMECUBE_CONTROLLER:
|
||||||
if (mIsFirstRun)
|
if (mIsFirstRun)
|
||||||
|
|
|
@ -33,9 +33,12 @@ import org.dolphinemu.dolphinemu.services.GameFileCacheService;
|
||||||
import org.dolphinemu.dolphinemu.ui.platform.Platform;
|
import org.dolphinemu.dolphinemu.ui.platform.Platform;
|
||||||
import org.dolphinemu.dolphinemu.ui.platform.PlatformGamesView;
|
import org.dolphinemu.dolphinemu.ui.platform.PlatformGamesView;
|
||||||
import org.dolphinemu.dolphinemu.utils.FileBrowserHelper;
|
import org.dolphinemu.dolphinemu.utils.FileBrowserHelper;
|
||||||
|
import org.dolphinemu.dolphinemu.utils.IniFile;
|
||||||
import org.dolphinemu.dolphinemu.utils.PermissionsHandler;
|
import org.dolphinemu.dolphinemu.utils.PermissionsHandler;
|
||||||
import org.dolphinemu.dolphinemu.utils.StartupHandler;
|
import org.dolphinemu.dolphinemu.utils.StartupHandler;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The main Activity of the Lollipop style UI. Manages several PlatformGamesFragments, which
|
* The main Activity of the Lollipop style UI. Manages several PlatformGamesFragments, which
|
||||||
* individually display a grid of available games for each Fragment, in a tabbed layout.
|
* individually display a grid of available games for each Fragment, in a tabbed layout.
|
||||||
|
@ -272,24 +275,19 @@ public final class MainActivity extends AppCompatActivity implements MainView
|
||||||
public void onTabSelected(@NonNull TabLayout.Tab tab)
|
public void onTabSelected(@NonNull TabLayout.Tab tab)
|
||||||
{
|
{
|
||||||
super.onTabSelected(tab);
|
super.onTabSelected(tab);
|
||||||
NativeLibrary
|
|
||||||
.SetConfig(SettingsFile.FILE_NAME_DOLPHIN + ".ini", Settings.SECTION_INI_ANDROID,
|
File dolphinFile = SettingsFile.getSettingsFile(SettingsFile.FILE_NAME_DOLPHIN);
|
||||||
SettingsFile.KEY_LAST_PLATFORM_TAB, Integer.toString(tab.getPosition()));
|
IniFile dolphinIni = new IniFile(dolphinFile);
|
||||||
|
dolphinIni.setInt(Settings.SECTION_INI_ANDROID, SettingsFile.KEY_LAST_PLATFORM_TAB,
|
||||||
|
tab.getPosition());
|
||||||
|
dolphinIni.save(dolphinFile);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
String platformTab = NativeLibrary
|
IniFile dolphinIni =
|
||||||
.GetConfig(SettingsFile.FILE_NAME_DOLPHIN + ".ini", Settings.SECTION_INI_ANDROID,
|
new IniFile(SettingsFile.getSettingsFile(SettingsFile.FILE_NAME_DOLPHIN));
|
||||||
SettingsFile.KEY_LAST_PLATFORM_TAB, "0");
|
mViewPager.setCurrentItem(dolphinIni.getInt(Settings.SECTION_INI_ANDROID,
|
||||||
|
SettingsFile.KEY_LAST_PLATFORM_TAB, 0));
|
||||||
try
|
|
||||||
{
|
|
||||||
mViewPager.setCurrentItem(Integer.parseInt(platformTab));
|
|
||||||
}
|
|
||||||
catch (NumberFormatException ex)
|
|
||||||
{
|
|
||||||
mViewPager.setCurrentItem(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
showGames();
|
showGames();
|
||||||
GameFileCacheService.startLoad(this);
|
GameFileCacheService.startLoad(this);
|
||||||
|
|
|
@ -0,0 +1,69 @@
|
||||||
|
package org.dolphinemu.dolphinemu.utils;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
|
||||||
|
// An in-memory copy of an INI file
|
||||||
|
public class IniFile
|
||||||
|
{
|
||||||
|
// This class is non-static to ensure that the IniFile parent does not get garbage collected
|
||||||
|
// while a section still is accessible. (The finalizer of IniFile deletes the native sections.)
|
||||||
|
public class Section
|
||||||
|
{
|
||||||
|
private long mPointer; // Do not rename or move without editing the native code
|
||||||
|
|
||||||
|
private Section(long pointer)
|
||||||
|
{
|
||||||
|
mPointer = pointer;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private long mPointer; // Do not rename or move without editing the native code
|
||||||
|
|
||||||
|
public IniFile()
|
||||||
|
{
|
||||||
|
mPointer = newIniFile();
|
||||||
|
}
|
||||||
|
|
||||||
|
public IniFile(String path)
|
||||||
|
{
|
||||||
|
this();
|
||||||
|
load(path, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
public IniFile(File file)
|
||||||
|
{
|
||||||
|
this();
|
||||||
|
load(file, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
public native boolean load(String path, boolean keepCurrentData);
|
||||||
|
|
||||||
|
public boolean load(File file, boolean keepCurrentData)
|
||||||
|
{
|
||||||
|
return load(file.getPath(), keepCurrentData);
|
||||||
|
}
|
||||||
|
|
||||||
|
public native boolean save(String path);
|
||||||
|
|
||||||
|
public boolean save(File file)
|
||||||
|
{
|
||||||
|
return save(file.getPath());
|
||||||
|
}
|
||||||
|
|
||||||
|
public native String getString(String sectionName, String key, String defaultValue);
|
||||||
|
|
||||||
|
public native boolean getBoolean(String sectionName, String key, boolean defaultValue);
|
||||||
|
|
||||||
|
public native int getInt(String sectionName, String key, int defaultValue);
|
||||||
|
|
||||||
|
public native void setString(String sectionName, String key, String newValue);
|
||||||
|
|
||||||
|
public native void setBoolean(String sectionName, String key, boolean newValue);
|
||||||
|
|
||||||
|
public native void setInt(String sectionName, String key, int newValue);
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public native void finalize();
|
||||||
|
|
||||||
|
private native long newIniFile();
|
||||||
|
}
|
|
@ -30,6 +30,12 @@ static jclass s_linked_hash_map_class;
|
||||||
static jmethodID s_linked_hash_map_init;
|
static jmethodID s_linked_hash_map_init;
|
||||||
static jmethodID s_linked_hash_map_put;
|
static jmethodID s_linked_hash_map_put;
|
||||||
|
|
||||||
|
static jclass s_ini_file_class;
|
||||||
|
static jfieldID s_ini_file_pointer;
|
||||||
|
static jclass s_ini_file_section_class;
|
||||||
|
static jfieldID s_ini_file_section_pointer;
|
||||||
|
static jmethodID s_ini_file_section_constructor;
|
||||||
|
|
||||||
namespace IDCache
|
namespace IDCache
|
||||||
{
|
{
|
||||||
JNIEnv* GetEnvForThread()
|
JNIEnv* GetEnvForThread()
|
||||||
|
@ -89,6 +95,7 @@ jmethodID GetAnalyticsValue()
|
||||||
{
|
{
|
||||||
return s_get_analytics_value;
|
return s_get_analytics_value;
|
||||||
}
|
}
|
||||||
|
|
||||||
jclass GetGameFileClass()
|
jclass GetGameFileClass()
|
||||||
{
|
{
|
||||||
return s_game_file_class;
|
return s_game_file_class;
|
||||||
|
@ -129,6 +136,31 @@ jmethodID GetLinkedHashMapPut()
|
||||||
return s_linked_hash_map_put;
|
return s_linked_hash_map_put;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
jclass GetIniFileClass()
|
||||||
|
{
|
||||||
|
return s_ini_file_class;
|
||||||
|
}
|
||||||
|
|
||||||
|
jfieldID GetIniFilePointer()
|
||||||
|
{
|
||||||
|
return s_ini_file_pointer;
|
||||||
|
}
|
||||||
|
|
||||||
|
jclass GetIniFileSectionClass()
|
||||||
|
{
|
||||||
|
return s_ini_file_section_class;
|
||||||
|
}
|
||||||
|
|
||||||
|
jfieldID GetIniFileSectionPointer()
|
||||||
|
{
|
||||||
|
return s_ini_file_section_pointer;
|
||||||
|
}
|
||||||
|
|
||||||
|
jmethodID GetIniFileSectionConstructor()
|
||||||
|
{
|
||||||
|
return s_ini_file_section_constructor;
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace IDCache
|
} // namespace IDCache
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
@ -150,16 +182,19 @@ jint JNI_OnLoad(JavaVM* vm, void* reserved)
|
||||||
s_do_rumble = env->GetStaticMethodID(s_native_library_class, "rumble", "(ID)V");
|
s_do_rumble = env->GetStaticMethodID(s_native_library_class, "rumble", "(ID)V");
|
||||||
s_get_update_touch_pointer =
|
s_get_update_touch_pointer =
|
||||||
env->GetStaticMethodID(s_native_library_class, "updateTouchPointer", "()V");
|
env->GetStaticMethodID(s_native_library_class, "updateTouchPointer", "()V");
|
||||||
|
env->DeleteLocalRef(native_library_class);
|
||||||
|
|
||||||
const jclass game_file_class = env->FindClass("org/dolphinemu/dolphinemu/model/GameFile");
|
const jclass game_file_class = env->FindClass("org/dolphinemu/dolphinemu/model/GameFile");
|
||||||
s_game_file_class = reinterpret_cast<jclass>(env->NewGlobalRef(game_file_class));
|
s_game_file_class = reinterpret_cast<jclass>(env->NewGlobalRef(game_file_class));
|
||||||
s_game_file_pointer = env->GetFieldID(game_file_class, "mPointer", "J");
|
s_game_file_pointer = env->GetFieldID(game_file_class, "mPointer", "J");
|
||||||
s_game_file_constructor = env->GetMethodID(game_file_class, "<init>", "(J)V");
|
s_game_file_constructor = env->GetMethodID(game_file_class, "<init>", "(J)V");
|
||||||
|
env->DeleteLocalRef(game_file_class);
|
||||||
|
|
||||||
const jclass game_file_cache_class =
|
const jclass game_file_cache_class =
|
||||||
env->FindClass("org/dolphinemu/dolphinemu/model/GameFileCache");
|
env->FindClass("org/dolphinemu/dolphinemu/model/GameFileCache");
|
||||||
s_game_file_cache_class = reinterpret_cast<jclass>(env->NewGlobalRef(game_file_cache_class));
|
s_game_file_cache_class = reinterpret_cast<jclass>(env->NewGlobalRef(game_file_cache_class));
|
||||||
s_game_file_cache_pointer = env->GetFieldID(game_file_cache_class, "mPointer", "J");
|
s_game_file_cache_pointer = env->GetFieldID(game_file_cache_class, "mPointer", "J");
|
||||||
|
env->DeleteLocalRef(game_file_cache_class);
|
||||||
|
|
||||||
const jclass analytics_class = env->FindClass("org/dolphinemu/dolphinemu/utils/Analytics");
|
const jclass analytics_class = env->FindClass("org/dolphinemu/dolphinemu/utils/Analytics");
|
||||||
s_analytics_class = reinterpret_cast<jclass>(env->NewGlobalRef(analytics_class));
|
s_analytics_class = reinterpret_cast<jclass>(env->NewGlobalRef(analytics_class));
|
||||||
|
@ -167,6 +202,20 @@ jint JNI_OnLoad(JavaVM* vm, void* reserved)
|
||||||
env->GetStaticMethodID(s_analytics_class, "sendReport", "(Ljava/lang/String;[B)V");
|
env->GetStaticMethodID(s_analytics_class, "sendReport", "(Ljava/lang/String;[B)V");
|
||||||
s_get_analytics_value = env->GetStaticMethodID(s_analytics_class, "getValue",
|
s_get_analytics_value = env->GetStaticMethodID(s_analytics_class, "getValue",
|
||||||
"(Ljava/lang/String;)Ljava/lang/String;");
|
"(Ljava/lang/String;)Ljava/lang/String;");
|
||||||
|
env->DeleteLocalRef(analytics_class);
|
||||||
|
|
||||||
|
const jclass ini_file_class = env->FindClass("org/dolphinemu/dolphinemu/utils/IniFile");
|
||||||
|
s_ini_file_class = reinterpret_cast<jclass>(env->NewGlobalRef(ini_file_class));
|
||||||
|
s_ini_file_pointer = env->GetFieldID(ini_file_class, "mPointer", "J");
|
||||||
|
env->DeleteLocalRef(ini_file_class);
|
||||||
|
|
||||||
|
const jclass ini_file_section_class =
|
||||||
|
env->FindClass("org/dolphinemu/dolphinemu/utils/IniFile$Section");
|
||||||
|
s_ini_file_section_class = reinterpret_cast<jclass>(env->NewGlobalRef(ini_file_section_class));
|
||||||
|
s_ini_file_section_pointer = env->GetFieldID(ini_file_section_class, "mPointer", "J");
|
||||||
|
s_ini_file_section_constructor = env->GetMethodID(
|
||||||
|
ini_file_section_class, "<init>", "(Lorg/dolphinemu/dolphinemu/utils/IniFile;J)V");
|
||||||
|
env->DeleteLocalRef(ini_file_section_class);
|
||||||
|
|
||||||
const jclass map_class = env->FindClass("java/util/LinkedHashMap");
|
const jclass map_class = env->FindClass("java/util/LinkedHashMap");
|
||||||
s_linked_hash_map_class = reinterpret_cast<jclass>(env->NewGlobalRef(map_class));
|
s_linked_hash_map_class = reinterpret_cast<jclass>(env->NewGlobalRef(map_class));
|
||||||
|
@ -188,6 +237,8 @@ void JNI_OnUnload(JavaVM* vm, void* reserved)
|
||||||
env->DeleteGlobalRef(s_game_file_cache_class);
|
env->DeleteGlobalRef(s_game_file_cache_class);
|
||||||
env->DeleteGlobalRef(s_analytics_class);
|
env->DeleteGlobalRef(s_analytics_class);
|
||||||
env->DeleteGlobalRef(s_linked_hash_map_class);
|
env->DeleteGlobalRef(s_linked_hash_map_class);
|
||||||
|
env->DeleteGlobalRef(s_ini_file_class);
|
||||||
|
env->DeleteGlobalRef(s_ini_file_section_class);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
|
|
@ -32,4 +32,10 @@ jclass GetLinkedHashMapClass();
|
||||||
jmethodID GetLinkedHashMapInit();
|
jmethodID GetLinkedHashMapInit();
|
||||||
jmethodID GetLinkedHashMapPut();
|
jmethodID GetLinkedHashMapPut();
|
||||||
|
|
||||||
|
jclass GetIniFileClass();
|
||||||
|
jfieldID GetIniFilePointer();
|
||||||
|
jclass GetIniFileSectionClass();
|
||||||
|
jfieldID GetIniFileSectionPointer();
|
||||||
|
jmethodID GetIniFileSectionConstructor();
|
||||||
|
|
||||||
} // namespace IDCache
|
} // namespace IDCache
|
||||||
|
|
|
@ -3,6 +3,7 @@ add_library(main SHARED
|
||||||
AndroidCommon/IDCache.cpp
|
AndroidCommon/IDCache.cpp
|
||||||
GameList/GameFile.cpp
|
GameList/GameFile.cpp
|
||||||
GameList/GameFileCache.cpp
|
GameList/GameFileCache.cpp
|
||||||
|
IniFile.cpp
|
||||||
MainAndroid.cpp
|
MainAndroid.cpp
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,121 @@
|
||||||
|
// Copyright 2020 Dolphin Emulator Project
|
||||||
|
// Licensed under GPLv2+
|
||||||
|
// Refer to the license.txt file included.
|
||||||
|
|
||||||
|
#include <jni.h>
|
||||||
|
|
||||||
|
#include "Common/IniFile.h"
|
||||||
|
#include "jni/AndroidCommon/AndroidCommon.h"
|
||||||
|
#include "jni/AndroidCommon/IDCache.h"
|
||||||
|
|
||||||
|
static IniFile::Section* GetSectionPointer(JNIEnv* env, jobject obj)
|
||||||
|
{
|
||||||
|
return reinterpret_cast<IniFile::Section*>(
|
||||||
|
env->GetLongField(obj, IDCache::GetIniFileSectionPointer()));
|
||||||
|
}
|
||||||
|
|
||||||
|
static IniFile* GetIniFilePointer(JNIEnv* env, jobject obj)
|
||||||
|
{
|
||||||
|
return reinterpret_cast<IniFile*>(env->GetLongField(obj, IDCache::GetIniFilePointer()));
|
||||||
|
}
|
||||||
|
|
||||||
|
static jobject SectionToJava(JNIEnv* env, jobject ini_file, IniFile::Section* section)
|
||||||
|
{
|
||||||
|
if (!section)
|
||||||
|
return nullptr;
|
||||||
|
|
||||||
|
return env->NewObject(IDCache::GetIniFileSectionClass(), IDCache::GetIniFileSectionConstructor(),
|
||||||
|
ini_file, reinterpret_cast<jlong>(section));
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
static T Get(JNIEnv* env, jobject obj, jstring section_name, jstring key, T default_value)
|
||||||
|
{
|
||||||
|
T result;
|
||||||
|
GetIniFilePointer(env, obj)
|
||||||
|
->GetOrCreateSection(GetJString(env, section_name))
|
||||||
|
->Get(GetJString(env, key), &result, default_value);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
static void Set(JNIEnv* env, jobject obj, jstring section_name, jstring key, T new_value)
|
||||||
|
{
|
||||||
|
GetIniFilePointer(env, obj)
|
||||||
|
->GetOrCreateSection(GetJString(env, section_name))
|
||||||
|
->Set(GetJString(env, key), new_value);
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
JNIEXPORT jboolean JNICALL Java_org_dolphinemu_dolphinemu_utils_IniFile_load(
|
||||||
|
JNIEnv* env, jobject obj, jstring path, jboolean keep_current_data)
|
||||||
|
{
|
||||||
|
return static_cast<jboolean>(
|
||||||
|
GetIniFilePointer(env, obj)->Load(GetJString(env, path), keep_current_data));
|
||||||
|
}
|
||||||
|
|
||||||
|
JNIEXPORT jboolean JNICALL Java_org_dolphinemu_dolphinemu_utils_IniFile_save(JNIEnv* env,
|
||||||
|
jobject obj,
|
||||||
|
jstring path)
|
||||||
|
{
|
||||||
|
return static_cast<jboolean>(GetIniFilePointer(env, obj)->Save(GetJString(env, path)));
|
||||||
|
}
|
||||||
|
|
||||||
|
JNIEXPORT jstring JNICALL Java_org_dolphinemu_dolphinemu_utils_IniFile_getString(
|
||||||
|
JNIEnv* env, jobject obj, jstring section_name, jstring key, jstring default_value)
|
||||||
|
{
|
||||||
|
return ToJString(env, Get(env, obj, section_name, key, GetJString(env, default_value)));
|
||||||
|
}
|
||||||
|
|
||||||
|
JNIEXPORT jboolean JNICALL Java_org_dolphinemu_dolphinemu_utils_IniFile_getBoolean(
|
||||||
|
JNIEnv* env, jobject obj, jstring section_name, jstring key, jboolean default_value)
|
||||||
|
{
|
||||||
|
return static_cast<jboolean>(Get(env, obj, section_name, key, static_cast<bool>(default_value)));
|
||||||
|
}
|
||||||
|
|
||||||
|
JNIEXPORT jint JNICALL Java_org_dolphinemu_dolphinemu_utils_IniFile_getInt(JNIEnv* env, jobject obj,
|
||||||
|
jstring section_name,
|
||||||
|
jstring key,
|
||||||
|
jint default_value)
|
||||||
|
{
|
||||||
|
return Get(env, obj, section_name, key, default_value);
|
||||||
|
}
|
||||||
|
|
||||||
|
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_utils_IniFile_setString(
|
||||||
|
JNIEnv* env, jobject obj, jstring section_name, jstring key, jstring new_value)
|
||||||
|
{
|
||||||
|
Set(env, obj, section_name, key, GetJString(env, new_value));
|
||||||
|
}
|
||||||
|
|
||||||
|
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_utils_IniFile_setBoolean(
|
||||||
|
JNIEnv* env, jobject obj, jstring section_name, jstring key, jboolean new_value)
|
||||||
|
{
|
||||||
|
Set(env, obj, section_name, key, static_cast<bool>(new_value));
|
||||||
|
}
|
||||||
|
|
||||||
|
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_utils_IniFile_setInt(JNIEnv* env, jobject obj,
|
||||||
|
jstring section_name,
|
||||||
|
jstring key,
|
||||||
|
jint new_value)
|
||||||
|
{
|
||||||
|
Set(env, obj, section_name, key, new_value);
|
||||||
|
}
|
||||||
|
|
||||||
|
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_utils_IniFile_finalize(JNIEnv* env,
|
||||||
|
jobject obj)
|
||||||
|
{
|
||||||
|
delete GetIniFilePointer(env, obj);
|
||||||
|
}
|
||||||
|
|
||||||
|
JNIEXPORT jlong JNICALL Java_org_dolphinemu_dolphinemu_utils_IniFile_newIniFile(JNIEnv* env,
|
||||||
|
jobject obj)
|
||||||
|
{
|
||||||
|
return reinterpret_cast<jlong>(new IniFile);
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
|
@ -213,10 +213,6 @@ JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_SaveScreenSh
|
||||||
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_eglBindAPI(JNIEnv* env,
|
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_eglBindAPI(JNIEnv* env,
|
||||||
jobject obj,
|
jobject obj,
|
||||||
jint api);
|
jint api);
|
||||||
JNIEXPORT jstring JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_GetConfig(
|
|
||||||
JNIEnv* env, jobject obj, jstring jFile, jstring jSection, jstring jKey, jstring jDefault);
|
|
||||||
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_SetConfig(
|
|
||||||
JNIEnv* env, jobject obj, jstring jFile, jstring jSection, jstring jKey, jstring jValue);
|
|
||||||
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_SetFilename(JNIEnv* env,
|
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_SetFilename(JNIEnv* env,
|
||||||
jobject obj,
|
jobject obj,
|
||||||
jstring jFile);
|
jstring jFile);
|
||||||
|
@ -355,129 +351,6 @@ JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_eglBindAPI(J
|
||||||
eglBindAPI(api);
|
eglBindAPI(api);
|
||||||
}
|
}
|
||||||
|
|
||||||
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_InitGameIni(JNIEnv* env,
|
|
||||||
jobject obj,
|
|
||||||
jstring jGameID)
|
|
||||||
{
|
|
||||||
// Initialize an empty INI file
|
|
||||||
IniFile ini;
|
|
||||||
std::string gameid = GetJString(env, jGameID);
|
|
||||||
|
|
||||||
__android_log_print(ANDROID_LOG_DEBUG, "InitGameIni", "Initializing base game config file");
|
|
||||||
ini.Save(File::GetUserPath(D_GAMESETTINGS_IDX) + gameid + ".ini");
|
|
||||||
}
|
|
||||||
|
|
||||||
JNIEXPORT jstring JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_GetUserSetting(
|
|
||||||
JNIEnv* env, jobject obj, jstring jGameID, jstring jSection, jstring jKey)
|
|
||||||
{
|
|
||||||
IniFile ini;
|
|
||||||
std::string gameid = GetJString(env, jGameID);
|
|
||||||
std::string section = GetJString(env, jSection);
|
|
||||||
std::string key = GetJString(env, jKey);
|
|
||||||
|
|
||||||
ini = SConfig::LoadGameIni(gameid, 0);
|
|
||||||
std::string value;
|
|
||||||
|
|
||||||
ini.GetOrCreateSection(section)->Get(key, &value, "-1");
|
|
||||||
|
|
||||||
return ToJString(env, value);
|
|
||||||
}
|
|
||||||
|
|
||||||
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_NewGameIniFile(JNIEnv* env,
|
|
||||||
jobject obj)
|
|
||||||
{
|
|
||||||
s_ini = IniFile();
|
|
||||||
}
|
|
||||||
|
|
||||||
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_LoadGameIniFile(JNIEnv* env,
|
|
||||||
jobject obj,
|
|
||||||
jstring jGameID)
|
|
||||||
{
|
|
||||||
std::string gameid = GetJString(env, jGameID);
|
|
||||||
s_ini.Load(File::GetUserPath(D_GAMESETTINGS_IDX) + gameid + ".ini");
|
|
||||||
}
|
|
||||||
|
|
||||||
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_SaveGameIniFile(JNIEnv* env,
|
|
||||||
jobject obj,
|
|
||||||
jstring jGameID)
|
|
||||||
{
|
|
||||||
std::string gameid = GetJString(env, jGameID);
|
|
||||||
s_ini.Save(File::GetUserPath(D_GAMESETTINGS_IDX) + gameid + ".ini");
|
|
||||||
}
|
|
||||||
|
|
||||||
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_SetUserSetting(
|
|
||||||
JNIEnv* env, jobject obj, jstring jGameID, jstring jSection, jstring jKey, jstring jValue)
|
|
||||||
{
|
|
||||||
std::string gameid = GetJString(env, jGameID);
|
|
||||||
std::string section = GetJString(env, jSection);
|
|
||||||
std::string key = GetJString(env, jKey);
|
|
||||||
std::string val = GetJString(env, jValue);
|
|
||||||
|
|
||||||
if (val != "-1")
|
|
||||||
{
|
|
||||||
s_ini.GetOrCreateSection(section)->Set(key, val);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
s_ini.GetOrCreateSection(section)->Delete(key);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_SetProfileSetting(
|
|
||||||
JNIEnv* env, jobject obj, jstring jProfile, jstring jSection, jstring jKey, jstring jValue)
|
|
||||||
{
|
|
||||||
IniFile ini;
|
|
||||||
std::string profile = GetJString(env, jProfile);
|
|
||||||
std::string section = GetJString(env, jSection);
|
|
||||||
std::string key = GetJString(env, jKey);
|
|
||||||
std::string val = GetJString(env, jValue);
|
|
||||||
|
|
||||||
ini.Load(File::GetUserPath(D_CONFIG_IDX) + "Profiles/Wiimote/" + profile + ".ini");
|
|
||||||
|
|
||||||
if (val != "-1")
|
|
||||||
{
|
|
||||||
ini.GetOrCreateSection(section)->Set(key, val);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
ini.GetOrCreateSection(section)->Delete(key);
|
|
||||||
}
|
|
||||||
|
|
||||||
ini.Save(File::GetUserPath(D_CONFIG_IDX) + "Profiles/Wiimote/" + profile + ".ini");
|
|
||||||
}
|
|
||||||
|
|
||||||
JNIEXPORT jstring JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_GetConfig(
|
|
||||||
JNIEnv* env, jobject obj, jstring jFile, jstring jSection, jstring jKey, jstring jDefault)
|
|
||||||
{
|
|
||||||
IniFile ini;
|
|
||||||
std::string file = GetJString(env, jFile);
|
|
||||||
std::string section = GetJString(env, jSection);
|
|
||||||
std::string key = GetJString(env, jKey);
|
|
||||||
std::string defaultValue = GetJString(env, jDefault);
|
|
||||||
|
|
||||||
ini.Load(File::GetUserPath(D_CONFIG_IDX) + std::string(file));
|
|
||||||
std::string value;
|
|
||||||
|
|
||||||
ini.GetOrCreateSection(section)->Get(key, &value, defaultValue);
|
|
||||||
|
|
||||||
return ToJString(env, value);
|
|
||||||
}
|
|
||||||
|
|
||||||
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_SetConfig(
|
|
||||||
JNIEnv* env, jobject obj, jstring jFile, jstring jSection, jstring jKey, jstring jValue)
|
|
||||||
{
|
|
||||||
IniFile ini;
|
|
||||||
std::string file = GetJString(env, jFile);
|
|
||||||
std::string section = GetJString(env, jSection);
|
|
||||||
std::string key = GetJString(env, jKey);
|
|
||||||
std::string value = GetJString(env, jValue);
|
|
||||||
|
|
||||||
ini.Load(File::GetUserPath(D_CONFIG_IDX) + std::string(file));
|
|
||||||
|
|
||||||
ini.GetOrCreateSection(section)->Set(key, value);
|
|
||||||
ini.Save(File::GetUserPath(D_CONFIG_IDX) + std::string(file));
|
|
||||||
}
|
|
||||||
|
|
||||||
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_SaveState(JNIEnv* env,
|
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_SaveState(JNIEnv* env,
|
||||||
jobject obj,
|
jobject obj,
|
||||||
jint slot,
|
jint slot,
|
||||||
|
|
Loading…
Reference in New Issue