TaskScript.java 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. /*
  2. * Copyright © 2004-2019 L2J Server
  3. *
  4. * This file is part of L2J Server.
  5. *
  6. * L2J Server is free software: you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License as published by
  8. * the Free Software Foundation, either version 3 of the License, or
  9. * (at your option) any later version.
  10. *
  11. * L2J Server is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  14. * General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU General Public License
  17. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  18. */
  19. package com.l2jserver.gameserver.taskmanager.tasks;
  20. import java.io.File;
  21. import org.slf4j.Logger;
  22. import org.slf4j.LoggerFactory;
  23. import com.l2jserver.gameserver.config.Config;
  24. import com.l2jserver.gameserver.scripting.ScriptEngineManager;
  25. import com.l2jserver.gameserver.taskmanager.Task;
  26. import com.l2jserver.gameserver.taskmanager.TaskManager.ExecutedTask;
  27. /**
  28. * @author janiii
  29. */
  30. public class TaskScript extends Task {
  31. private static final Logger LOG = LoggerFactory.getLogger(TaskScript.class);
  32. private static final String NAME = "script";
  33. @Override
  34. public String getName() {
  35. return NAME;
  36. }
  37. @Override
  38. public void onTimeElapsed(ExecutedTask task) {
  39. final File file = new File(Config.SCRIPT_ROOT, "com/l2jserver/datapack/cron/" + task.getParams()[2]);
  40. if (!file.isFile()) {
  41. LOG.warn("File not found {}!", task.getParams()[2]);
  42. return;
  43. }
  44. try {
  45. ScriptEngineManager.getInstance().compileScript(file);
  46. } catch (Exception ex) {
  47. LOG.warn("Failed loading {}!", task.getParams()[2]);
  48. }
  49. }
  50. }