view dwt/browser/FilePicker_1_8.d @ 45:d8635bb48c7c

Merge with SWT 3.5
author Jacob Carlborg <doob@me.com>
date Mon, 01 Dec 2008 17:07:00 +0100
parents e831403a80a9
children 5583f8eeee6c
line wrap: on
line source

/*******************************************************************************
 * Copyright (c) 2003, 2007 IBM Corporation and others.
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * which accompanies this distribution, and is available at
 * http://www.eclipse.org/legal/epl-v10.html
 *
 * Contributors:
 *     IBM Corporation - initial API and implementation
 *******************************************************************************/
module dwt.browser.FilePicker_1_8;

import dwt.dwthelper.utils;

import dwt.internal.mozilla.XPCOM;
import dwt.internal.mozilla.XPCOMObject;

class FilePicker_1_8 : FilePicker {

void createCOMInterfaces () {
    /* Create each of the interfaces that this object implements */
    supports = new XPCOMObject (new int[] {2, 0, 0}) {
        public int /*long*/ method0 (int /*long*/[] args) {return QueryInterface (args[0], args[1]);}
        public int /*long*/ method1 (int /*long*/[] args) {return AddRef ();}
        public int /*long*/ method2 (int /*long*/[] args) {return Release ();}
    };

    filePicker = new XPCOMObject (new int[] {2, 0, 0, 3, 1, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1}) {
        public int /*long*/ method0 (int /*long*/[] args) {return QueryInterface (args[0], args[1]);}
        public int /*long*/ method1 (int /*long*/[] args) {return AddRef ();}
        public int /*long*/ method2 (int /*long*/[] args) {return Release ();}
        public int /*long*/ method3 (int /*long*/[] args) {return Init (args[0], args[1], cast(short)args[2]);}
        public int /*long*/ method4 (int /*long*/[] args) {return AppendFilters (cast(int)/*64*/args[0]);}
        public int /*long*/ method5 (int /*long*/[] args) {return AppendFilter (args[0], args[1]);}
        public int /*long*/ method6 (int /*long*/[] args) {return GetDefaultString (args[0]);}
        public int /*long*/ method7 (int /*long*/[] args) {return SetDefaultString (args[0]);}
        public int /*long*/ method8 (int /*long*/[] args) {return GetDefaultExtension (args[0]);}
        public int /*long*/ method9 (int /*long*/[] args) {return SetDefaultExtension (args[0]);}
        public int /*long*/ method10 (int /*long*/[] args) {return GetFilterIndex (args[0]);}
        public int /*long*/ method11 (int /*long*/[] args) {return SetFilterIndex (cast(int)/*64*/args[0]);}
        public int /*long*/ method12 (int /*long*/[] args) {return GetDisplayDirectory (args[0]);}
        public int /*long*/ method13 (int /*long*/[] args) {return SetDisplayDirectory (args[0]);}
        public int /*long*/ method14 (int /*long*/[] args) {return GetFile (args[0]);}
        public int /*long*/ method15 (int /*long*/[] args) {return GetFileURL (args[0]);}
        public int /*long*/ method16 (int /*long*/[] args) {return GetFiles (args[0]);}
        public int /*long*/ method17 (int /*long*/[] args) {return Show (args[0]);}
    };
}

/*
 * As of Mozilla 1.8 some of nsIFilePicker's string arguments changed type.  This method
 * answers a java string based on the type of string that is appropriate for the Mozilla
 * version being used.
 */
String parseAString (int /*long*/ string) {
    if (string is 0) return null;
    int length = XPCOM.nsEmbedString_Length (string);
    int /*long*/ buffer = XPCOM.nsEmbedString_get (string);
    char[] chars = new char[length];
    XPCOM.memmove (chars, buffer, length * 2);
    return new String (chars);
}
}