org.netbeans.modules.maven.model.Utilities Maven / Gradle / Ivy
The newest version!
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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 org.netbeans.modules.maven.model;
import java.io.File;
import java.io.IOException;
import java.io.OutputStream;
import java.nio.charset.StandardCharsets;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.atomic.AtomicBoolean;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.swing.SwingUtilities;
import javax.swing.event.DocumentEvent;
import javax.swing.event.DocumentListener;
import javax.swing.text.BadLocationException;
import javax.swing.text.Document;
import org.netbeans.editor.BaseDocument;
import org.netbeans.editor.GuardedDocument;
import org.netbeans.modules.editor.NbEditorUtilities;
import org.netbeans.modules.maven.model.pom.Build;
import org.netbeans.modules.maven.model.pom.POMModel;
import org.netbeans.modules.maven.model.pom.POMModelFactory;
import org.netbeans.modules.maven.model.pom.Plugin;
import org.netbeans.modules.maven.model.settings.SettingsModel;
import org.netbeans.modules.maven.model.settings.SettingsModelFactory;
import org.netbeans.modules.xml.xam.ComponentEvent;
import org.netbeans.modules.xml.xam.ComponentListener;
import org.netbeans.modules.xml.xam.Model;
import org.netbeans.modules.xml.xam.ModelSource;
import org.netbeans.modules.xml.xam.dom.AbstractDocumentModel;
import org.openide.awt.StatusDisplayer;
import org.openide.cookies.EditorCookie;
import org.openide.cookies.SaveCookie;
import org.openide.filesystems.FileObject;
import org.openide.filesystems.FileSystem;
import org.openide.filesystems.FileUtil;
import org.openide.loaders.DataObject;
import org.openide.text.Line;
import org.openide.util.Exceptions;
import org.openide.util.Lookup;
import org.openide.util.NbBundle;
import org.openide.util.UserQuestionException;
import org.openide.util.lookup.AbstractLookup;
import org.openide.util.lookup.InstanceContent;
import org.openide.util.lookup.Lookups;
/**
* Utility class to create ModelSource (environment) for the
* to be created models.
*
* copied from xml.retriever and customized.
* @author mkleint
*/
public class Utilities {
private Utilities() {}
private static final Logger logger = Logger.getLogger(Utilities.class.getName());
/**
*
* @param file
* @param editable
* @param skeleton current content of the document
* @param mimeType
* @return
*/
public static ModelSource createModelSourceForMissingFile(File file, boolean editable, String skeleton, String mimeType) {
try {
BaseDocument doc = new BaseDocument(false, mimeType);
doc.insertString(0, skeleton, null);
InstanceContent ic = new InstanceContent();
Lookup lookup = new AbstractLookup(ic);
ic.add(file);
ic.add(doc);
ModelSource ms = new ModelSource(lookup, editable);
return ms;
} catch (BadLocationException ex) {
Exceptions.printStackTrace(ex);
}
assert false : "Failed to load the model for non-existing file";
return null;
}
private static BaseDocument getDocument(final DataObject modelSourceDataObject) throws IOException {
if (modelSourceDataObject != null && modelSourceDataObject.isValid()) {
EditorCookie ec = modelSourceDataObject.getLookup().lookup(EditorCookie.class);
assert ec != null : "Data object "+modelSourceDataObject.getPrimaryFile().getPath()+" has no editor cookies.";
Document doc;
try {
doc = ec.openDocument();
} catch (UserQuestionException uce) {
// this exception is thrown if the document is to large
// lets just confirm that it is ok
uce.confirmed();
doc = ec.openDocument();
}
if (doc instanceof BaseDocument) {
return (BaseDocument) doc;
} else {
logger.log(Level.FINER, "Got document of unexpected {0} from {1}", new Object[] {doc.getClass(), modelSourceDataObject});
// Replace with a BaseDocument. Mostly useful for unit test.
final BaseDocument doc2 = new GuardedDocument("text/xml");
try {
String str = doc.getText(0, doc.getLength());
doc2.insertString(0, str, null);
} catch (BadLocationException x) {
throw new IOException(x);
}
final Document orig = doc;
doc2.addDocumentListener(new DocumentListener() {
public @Override void insertUpdate(DocumentEvent e) {
try {
orig.insertString(e.getOffset(), doc2.getText(e.getOffset(), e.getLength()), null);
} catch (BadLocationException x) {
assert false : x;
}
}
public @Override void removeUpdate(DocumentEvent e) {
try {
orig.remove(e.getOffset(), e.getLength());
} catch (BadLocationException x) {
assert false : x;
}
}
public @Override void changedUpdate(DocumentEvent e) {}
});
doc2.putProperty(Document.StreamDescriptionProperty, doc.getProperty(Document.StreamDescriptionProperty));
return doc2;
}
} else {
return null;
}
}
/**
* This method could be overridden by the Unit testcase to return a special
* ModelSource object for a FileObject with custom impl of classes added to the lookup.
* This is optional if both getDocument(FO) and createCatalogModel(FO) are overridden.
* @param thisFileObj
* @return
*/
public static ModelSource createModelSource(final FileObject thisFileObj) {
return createModelSource(thisFileObj, null, null);
}
public static ModelSource createModelSource(final FileObject thisFileObj, final Document document) {
if (!(document instanceof BaseDocument)) {
throw new IllegalArgumentException();
}
return createModelSource(thisFileObj, null, (BaseDocument)document);
}
public static ModelSource createModelSource(final FileObject thisFileObj, final DataObject dobject, final BaseDocument document) {
assert thisFileObj != null : "Null file object.";
final File fl = FileUtil.toFile(thisFileObj);
boolean editable = (fl != null);// && thisFileObj.canWrite();
Lookup proxyLookup = Lookups.proxy(new Lookup.Provider() {
@Override
public Lookup getLookup() {
List
© 2015 - 2025 Weber Informatics LLC | Privacy Policy