1
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2
/* ***** BEGIN LICENSE BLOCK *****
3
* Version: NPL 1.1/GPL 2.0/LGPL 2.1
5
* The contents of this file are subject to the Netscape Public License
6
* Version 1.1 (the "License"); you may not use this file except in
7
* compliance with the License. You may obtain a copy of the License at
8
* http://www.mozilla.org/NPL/
10
* Software distributed under the License is distributed on an "AS IS" basis,
11
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
12
* for the specific language governing rights and limitations under the
15
* The Original Code is mozilla.org code.
17
* The Initial Developer of the Original Code is
18
* Netscape Communications Corporation.
19
* Portions created by the Initial Developer are Copyright (C) 1998
20
* the Initial Developer. All Rights Reserved.
25
* Alternatively, the contents of this file may be used under the terms of
26
* either the GNU General Public License Version 2 or later (the "GPL"), or
27
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
28
* in which case the provisions of the GPL or the LGPL are applicable instead
29
* of those above. If you wish to allow use of your version of this file only
30
* under the terms of either the GPL or the LGPL, and not to allow others to
31
* use your version of this file under the terms of the NPL, indicate your
32
* decision by deleting the provisions above and replace them with the notice
33
* and other provisions required by the GPL or the LGPL. If you do not delete
34
* the provisions above, a recipient may use your version of this file under
35
* the terms of any one of the NPL, the GPL or the LGPL.
37
* ***** END LICENSE BLOCK ***** */
39
#include "nsISupports.idl"
40
#include "nsISelectionListener.idl"
41
#include "nsIEnumerator.idl"
43
interface nsIDOMRange;
44
interface nsISelectionListener;
52
[ptr] native nsIFrame(nsIFrame);
53
[ptr] native nsIPresShell(nsIPresShell);
54
[ref] native nsPointRef(nsPoint);
56
[scriptable, uuid(2d5535e2-1dd2-11b2-8e38-d53ec833adf6)]
57
interface nsISelectionPrivate : nsISupports
59
const short ENDOFPRECEDINGLINE=0;
60
const short STARTOFNEXTLINE=1;
62
attribute boolean interlinePosition;
65
match this up with endbatchChanges. will stop ui updates while multiple selection methods are called
67
void startBatchChanges();
70
match this up with startBatchChanges
72
void endBatchChanges();
74
nsIEnumerator getEnumerator();
75
wstring toStringWithFormat(in string formatType, in unsigned long flags, in PRInt32 wrapColumn);
76
void addSelectionListener(in nsISelectionListener newListener);
77
void removeSelectionListener(in nsISelectionListener listenerToRemove);
79
/* Table selection stuff
80
We should probably move this and table-related
81
items in nsIFrameSelection to a
82
new nsITableSelection interface
84
const long TABLESELECTION_NONE = 0;
85
const long TABLESELECTION_CELL = 1;
86
const long TABLESELECTION_ROW = 2;
87
const long TABLESELECTION_COLUMN = 3;
88
const long TABLESELECTION_TABLE = 4;
89
const long TABLESELECTION_ALLCELLS = 5;
91
/** Test if supplied range points to a single table element:
92
* Result is one of above constants. "None" means
93
* a table element isn't selected.
95
long getTableSelectionType(in nsIDOMRange range);
97
/* Internal utility method to set the pres shell on a newly created selection */
98
[noscript] void setPresShell(in nsIPresShell aPresShell);
100
/* canCacheFrameOffset
101
* Frame Offset cache can be used just during calling nsEditor::EndPlaceHolderTransaction.
102
* EndPlaceHolderTransaction will give rise to reflow/refreshing view/scroll, and call times
103
* of nsTextFrame::GetPointFromOffset whose return value is to be cached.
104
* see bugs 35296 and 199412
106
[noscript] attribute boolean canCacheFrameOffset;
108
/* GetCachedOffsetForFrame
109
* Returns cached value for nsTextFrame::GetPointFromOffset.
111
[noscript] void getCachedFrameOffset(in nsIFrame aFrame, in PRInt32 inOffset, in nsPointRef aPoint);