package com.perforce.p4simulink.util; /** * Copyright (C) 2014 Perforce Software. All rights reserved. * * Please see LICENSE.txt in top-level folder of this distribution. */ import org.apache.logging.log4j.Level; import org.apache.logging.log4j.Logger; import com.mathworks.cmlink.api.ConfigurationManagementException; import com.perforce.p4java.exception.P4JavaException; import com.perforce.p4simulink.P4CMException; public class Logging { public static void logException(Logger logger, ConfigurationManagementException e) throws ConfigurationManagementException { logException(logger, e, false); } public static void logException(Logger logger, P4JavaException e) throws ConfigurationManagementException { logException(logger, e, false); } public static void logException(Logger logger, P4CMException e) throws P4CMException { logException(logger, e, false); } public static void logException(Logger logger, P4CMException e, boolean rethrow) throws P4CMException { logger.error("Exception: " + e.getLocalizedMessage()); e.printStackTrace(logger.getStream(Level.ERROR)); if (rethrow) { throw e; } } public static void logException(Logger logger, ConfigurationManagementException e, boolean rethrow) throws ConfigurationManagementException { logger.error("Exception: " + e.getLocalizedMessage()); e.printStackTrace(logger.getStream(Level.ERROR)); if (rethrow) { throw e; } } public static void logException(Logger logger, P4JavaException e, boolean rethrow) throws ConfigurationManagementException { logger.error("Exception [P4Java]: " + e.getLocalizedMessage()); e.printStackTrace(logger.getStream(Level.ERROR)); if (rethrow) { throw new ConfigurationManagementException(e); } } }
# | Change | User | Description | Committed | |
---|---|---|---|---|---|
#1 | 11898 | Paul Allen |
Populate -o //guest/perforce_software/p4sl/main/... //guest/paul_allen/p4sl/.... |
||
//guest/perforce_software/p4sl/main/src/main/java/com/perforce/p4simulink/util/Logging.java | |||||
#9 | 11672 | Paul Allen |
Tidy up formatting and imports. No functional change. |
||
#8 | 11659 | Paul Allen |
Performance improvements, continued: improved performance of getFileState() by replacing the client haveList call with a direct server command. Also improved isLatest by removing fstat calls and replacing with simpler calls to diff and sync. Transferred from p4://perforce.perforce.com:1666@983506 |
||
#7 | 11652 | Paul Allen |
Added boilerplate to code, fixed build issues (NPEs on plugin load), removed Mathworks classes from plugin jar, fixed delete vs missing issue on remove() call. Transferred from p4://perforce.perforce.com:1666@970498 |
||
#6 | 11647 | Paul Allen |
New project creation fixes. Transferred from p4://perforce.perforce.com:1666@958305 |
||
#5 | 11645 | Paul Allen |
Refactoring and additional work on UI: Removed Connection class and went with global server/client objects. Implemented panes for connection, depot path and passwords. Passwords are only requested when required. Transferred from p4://perforce.perforce.com:1666@957149 |
||
#4 | 11643 | Paul Allen |
Unshelved from pending changelist '953729': Paul: Added: - getWorkspaceState() -- run a p4 status - getOpenedState() -- run p4 opened - getIgnoreState() -- run p4 add -n Modified: - add() -- seemed to call reopen? - P4FileState -- simple constructor for state Elliot: * global client and changelist object within the adapter * removed repeated client updates and changelist refreshes * removed 'reopen' in add * added calls to 'edit' where appropriate file states are found * made 'checkout' a pure sync, with no edits * commented a bunch of the @Override methods * added a call to haveList in getFileState so we can see versions of files in the project * changed the connection pane to look like p4v's * refactored a bit of the dialogue code, added calls to prompt for password (like p4v) * changed all log.trace() calls to log.debug() so the log file messiness can be controlled more easily Functionality that now works properly: * open project from source control, with properly-configured .p4config file * add new project to source control, with properly-configured .p4config file * add * edit * commit * revert * compare reversions (opens Simulink diff tool) Things to work on: * dialogues (particularily the password one, but the connection one is a bit dodge-y) * remove from project (possibly always making the Simulink project meta-data editable will fix this - it *almost* works) - the current issue is Simulink needs to edit the meta-data, but Perforce has made the files read-only, so Simulink throws up on itself Transferred from p4://perforce.perforce.com:1666@954622 |
||
#3 | 11642 | Paul Allen |
More fixes from discussion with Paul and after looking at other integrations work. Transferred from p4://perforce.perforce.com:1666@953553 |
||
#2 | 11641 | Paul Allen |
Fixes from chat with Paul. Transferred from p4://perforce.perforce.com:1666@953389 |
||
#1 | 11637 | Paul Allen |
Fix up isLatest, uncheckout, add back code that searched for a .p4rc file within the sandbox directory first, then looks in ~/.p4simulink/ and finally ~/. Transferred from p4://perforce.perforce.com:1666@950121 |