source: trunk/src/org/expeditee/importer/FileImporter.java@ 1436

Last change on this file since 1436 was 1436, checked in by bnemhaus, 5 years ago

Added the ability to copy/paste recognised files (mostly images) into Expeditee. This functionality already existed when drag n dropping, but now also works when using copy/paste.

At this stage, recognised files get imported as a approapriate Text Item. For example, a image will create a @i Text Item and attach it to your cursor. Ideally this would be the image directly. Unfortunately, items attached to the cursor (FreeItems) are not currently parsed. This is something I will discuss with David as there are confounding issues to consider. For example: surrogates...

Attached to the bottom of this commit message are my current thoughts.

Also made it so when creating a @i through DND or Copy/Paste, that @i is as relative as possible. The users image directories setting is used to achieve this.


  • FreeItems need to be parsed...we would need to deal with primaries/surrogates in them...
  • Do we want FreeItems to be parsed? If I attach an item to my cursor and then enter surrogate mode, should it change?
  • My gut says no. Both because it would be work, and also because it kind of feels like a free win if we do not.
  • But we do want to replace @i with images etc. Therefore, we want an old style parse for FreeItems?
File size: 1.8 KB
Line 
1/**
2 * FileImporter.java
3 * Copyright (C) 2010 New Zealand Digital Library, http://expeditee.org
4 *
5 * This program is free software: you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation, either version 3 of the License, or
8 * (at your option) any later version.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License
16 * along with this program. If not, see <http://www.gnu.org/licenses/>.
17 */
18
19package org.expeditee.importer;
20
21import java.io.File;
22import java.io.IOException;
23
24import org.expeditee.core.Point;
25import org.expeditee.items.Item;
26
27/**
28 * Used for importing files (and folders) into Expeditee. A FileImporter
29 * may or maynot choose to import a file.
30 *
31 * @author Brook Novak
32 *
33 */
34public interface FileImporter {
35
36 /**
37 * Invoked when a file (or directory) is to be imported.
38 *
39 * The importer can choose whether or not to stop other importers to import
40 * the files by returning true.
41 *
42 * @param f
43 * The file to import. Not null.
44 * @param location
45 * The location in expeditee space where the import was requested.
46 * Null if not applicable.
47 * @param attachToFreeItems TODO
48 *
49 * @return
50 * True to stop the import handling proccess for this file. False to allow other
51 * potential import handlers to also import the file.
52 * Should always return false if cannot handle the file.
53 *
54 * @throws IOException
55 * If the import procedure failed.
56 */
57 Item importFile(File f, Point location, boolean attachToFreeItems) throws IOException;
58}
Note: See TracBrowser for help on using the repository browser.