mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-19 05:53:35 +00:00
Patches from Dekel (2) and a bit more
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/branches/lyx-1_1_5@1124 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
parent
da3b03ed1e
commit
ca3b6674be
22
ChangeLog
22
ChangeLog
@ -1,3 +1,25 @@
|
|||||||
|
2000-10-14 Dekel Tsur <dekelts@tau.ac.il>
|
||||||
|
|
||||||
|
* src/text.C (Backspace): Make sure that the row of the cursor is
|
||||||
|
rebreaked.
|
||||||
|
|
||||||
|
* src/lyxfunc.C (Dispatch): Set CurrentState() in minibuffer after
|
||||||
|
insertion of a char.
|
||||||
|
|
||||||
|
* src/lyx_gui.C (init): Prevent a crash when only one font from
|
||||||
|
menu/popup fonts is not found.
|
||||||
|
|
||||||
|
* lib/lyxrc.example: Add an example for binding a key for language
|
||||||
|
switching.
|
||||||
|
|
||||||
|
2000-10-13 Dekel Tsur <dekelts@tau.ac.il>
|
||||||
|
|
||||||
|
* src/text.C (GetColumnNearX): Better behavior when a RTL
|
||||||
|
paragraph is ended by LTR text.
|
||||||
|
|
||||||
|
* src/text2.C (SetCurrentFont,CursorLeftIntern,CursorRightIntern):
|
||||||
|
ditto.
|
||||||
|
|
||||||
2000-10-13 Jean-Marc Lasgouttes <Jean-Marc.Lasgouttes@inria.fr>
|
2000-10-13 Jean-Marc Lasgouttes <Jean-Marc.Lasgouttes@inria.fr>
|
||||||
|
|
||||||
* README: add a description of our numbering scheme
|
* README: add a description of our numbering scheme
|
||||||
|
10
README
10
README
@ -1,4 +1,4 @@
|
|||||||
Preamble: LyX versionning scheme
|
Preamble: LyX version scheme
|
||||||
|
|
||||||
In September of 1999 the LyX Team decided that we could no
|
In September of 1999 the LyX Team decided that we could no
|
||||||
longer successfully use the two strand development process
|
longer successfully use the two strand development process
|
||||||
@ -17,9 +17,7 @@ Preamble: LyX versionning scheme
|
|||||||
|
|
||||||
* Establishing the foundations of GUI/system independence,
|
* Establishing the foundations of GUI/system independence,
|
||||||
|
|
||||||
* Rearrangement of the directory structure,
|
* Rearrangement of the directory structure.
|
||||||
|
|
||||||
* Use of libtool, automake and autoconf.
|
|
||||||
|
|
||||||
Once the transition is over the 1.1 series should be very
|
Once the transition is over the 1.1 series should be very
|
||||||
stable and we will then release 1.2.0. This new series will be
|
stable and we will then release 1.2.0. This new series will be
|
||||||
@ -28,9 +26,9 @@ Preamble: LyX versionning scheme
|
|||||||
occurring in branches of CVS and once the feature/modification
|
occurring in branches of CVS and once the feature/modification
|
||||||
has proved stable it will be merged into the main releases.
|
has proved stable it will be merged into the main releases.
|
||||||
|
|
||||||
Versionning uses a continuous numbering scheme where odd or
|
LyX now uses a continuous numbering scheme where odd or
|
||||||
even numbering is no longer significant. Prereleases are
|
even numbering is no longer significant. Prereleases are
|
||||||
labelled with a "pre" suffix and any fixes required between
|
labeled with a "pre" suffix and any fixes required between
|
||||||
stable releases have a "fix" suffix. Thus there are three
|
stable releases have a "fix" suffix. Thus there are three
|
||||||
possible file names:
|
possible file names:
|
||||||
|
|
||||||
|
@ -640,6 +640,12 @@
|
|||||||
# Default is "true"
|
# Default is "true"
|
||||||
#\mark_foreign_language false
|
#\mark_foreign_language false
|
||||||
|
|
||||||
|
# It is possible to bind keys for changing the language inside a document.
|
||||||
|
# For example, the following command will cause F12 to switch between French
|
||||||
|
# and English in a French document, and in a document of other language it will
|
||||||
|
# switch between that language and French.
|
||||||
|
#\bind "F12" "language french"
|
||||||
|
|
||||||
#
|
#
|
||||||
# HEBREW SUPPORT SECTION ####################################################
|
# HEBREW SUPPORT SECTION ####################################################
|
||||||
#
|
#
|
||||||
|
@ -197,35 +197,41 @@ void LyXGUI::init()
|
|||||||
if (lyxrc.font_norm_menu.empty())
|
if (lyxrc.font_norm_menu.empty())
|
||||||
lyxrc.font_norm_menu = lyxrc.font_norm;
|
lyxrc.font_norm_menu = lyxrc.font_norm;
|
||||||
// Set the font name for popups and menus
|
// Set the font name for popups and menus
|
||||||
string menufontname = lyxrc.menu_font_name
|
string boldfontname = lyxrc.menu_font_name
|
||||||
+ "-*-*-*-?-*-*-*-*-"
|
+ "-*-*-*-?-*-*-*-*-"
|
||||||
+ lyxrc.font_norm_menu;
|
+ lyxrc.font_norm_menu;
|
||||||
// "?" means "scale that font"
|
// "?" means "scale that font"
|
||||||
string popupfontname = lyxrc.popup_font_name
|
string fontname = lyxrc.popup_font_name
|
||||||
+ "-*-*-*-?-*-*-*-*-"
|
+ "-*-*-*-?-*-*-*-*-"
|
||||||
+ lyxrc.font_norm_menu;
|
+ lyxrc.font_norm_menu;
|
||||||
|
|
||||||
int bold = fl_set_font_name(FL_BOLD_STYLE, menufontname.c_str());
|
int bold = fl_set_font_name(FL_BOLD_STYLE, boldfontname.c_str());
|
||||||
int normal = fl_set_font_name(FL_NORMAL_STYLE, popupfontname.c_str());
|
int normal = fl_set_font_name(FL_NORMAL_STYLE, fontname.c_str());
|
||||||
if (bold < 0)
|
if (bold < 0)
|
||||||
lyxerr << "Could not set menu font to "
|
lyxerr << "Could not set menu font to "
|
||||||
<< menufontname << endl;
|
<< boldfontname << endl;
|
||||||
|
|
||||||
if (normal < 0)
|
if (normal < 0)
|
||||||
lyxerr << "Could not set popup font to "
|
lyxerr << "Could not set popup font to "
|
||||||
<< popupfontname << endl;
|
<< fontname << endl;
|
||||||
|
|
||||||
if (bold < 0 && normal < 0) {
|
if (bold < 0 && normal < 0) {
|
||||||
lyxerr << "Using 'helvetica' font for menus" << endl;
|
lyxerr << "Using 'helvetica' font for menus" << endl;
|
||||||
bold = fl_set_font_name(FL_BOLD_STYLE,
|
boldfontname = "-*-helvetica-bold-r-*-*-*-?-*-*-*-*-iso8859-1";
|
||||||
"-*-helvetica-bold-r-*-*-*-?-*-*-*-*-iso8859-1");
|
fontname = "-*-helvetica-medium-r-*-*-*-?-*-*-*-*-iso8859-1";
|
||||||
normal = fl_set_font_name(FL_NORMAL_STYLE,
|
bold = fl_set_font_name(FL_BOLD_STYLE, boldfontname.c_str());
|
||||||
"-*-helvetica-medium-r-*-*-*-?-*-*-*-*-iso8859-1");
|
normal = fl_set_font_name(FL_NORMAL_STYLE, fontname.c_str());
|
||||||
|
|
||||||
if (bold < 0 && normal < 0) {
|
if (bold < 0 && normal < 0) {
|
||||||
lyxerr << "Could not find helvetica font. Using 'fixed'." << endl;
|
lyxerr << "Could not find helvetica font. Using 'fixed'." << endl;
|
||||||
normal = fl_set_font_name(FL_NORMAL_STYLE, "fixed");
|
fl_set_font_name(FL_NORMAL_STYLE, "fixed");
|
||||||
|
normal = bold = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (bold < 0)
|
||||||
|
fl_set_font_name(FL_BOLD_STYLE, fontname.c_str());
|
||||||
|
else if (normal < 0)
|
||||||
|
fl_set_font_name(FL_NORMAL_STYLE, boldfontname.c_str());
|
||||||
|
|
||||||
// put here (after fl_initialize) to avoid segfault. Cannot be done
|
// put here (after fl_initialize) to avoid segfault. Cannot be done
|
||||||
// in setDefaults() (Matthias 140496)
|
// in setDefaults() (Matthias 140496)
|
||||||
|
@ -2575,6 +2575,10 @@ string LyXFunc::Dispatch(int ac,
|
|||||||
owner->view()->text->sel_cursor =
|
owner->view()->text->sel_cursor =
|
||||||
owner->view()->text->cursor;
|
owner->view()->text->cursor;
|
||||||
moveCursorUpdate(false);
|
moveCursorUpdate(false);
|
||||||
|
|
||||||
|
// current_font.number can change so we need to update
|
||||||
|
// the minibuffer
|
||||||
|
owner->getMiniBuffer()->Set(CurrentState(owner->view()));
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -2692,6 +2696,9 @@ string LyXFunc::Dispatch(int ac,
|
|||||||
owner->view()->text->sel_cursor =
|
owner->view()->text->sel_cursor =
|
||||||
owner->view()->text->cursor;
|
owner->view()->text->cursor;
|
||||||
moveCursorUpdate(false);
|
moveCursorUpdate(false);
|
||||||
|
// current_font.number can change so we need to update
|
||||||
|
// the minibuffer
|
||||||
|
owner->getMiniBuffer()->Set(CurrentState(owner->view()));
|
||||||
return string();
|
return string();
|
||||||
} else {
|
} else {
|
||||||
// why is an "Unknown action" with empty
|
// why is an "Unknown action" with empty
|
||||||
|
30
src/text.C
30
src/text.C
@ -3701,9 +3701,20 @@ void LyXText::Backspace()
|
|||||||
|
|
||||||
BreakAgainOneRow(row);
|
BreakAgainOneRow(row);
|
||||||
SetCursor(cursor.par, cursor.pos, false, cursor.boundary);
|
SetCursor(cursor.par, cursor.pos, false, cursor.boundary);
|
||||||
// cursor MUST be in row now
|
// will the cursor be in another row now?
|
||||||
|
if (row->next && row->next->par == row->par &&
|
||||||
|
RowLast(row) <= cursor.pos) {
|
||||||
|
row = row->next;
|
||||||
|
BreakAgainOneRow(row);
|
||||||
|
}
|
||||||
|
|
||||||
|
SetCursor(cursor.par, cursor.pos,
|
||||||
|
false, cursor.boundary);
|
||||||
|
|
||||||
need_break_row = row->next;
|
if (row->next && row->next->par == row->par)
|
||||||
|
need_break_row = row->next;
|
||||||
|
else
|
||||||
|
need_break_row = 0;
|
||||||
} else {
|
} else {
|
||||||
// set the dimensions of the row
|
// set the dimensions of the row
|
||||||
row->fill = Fill(row, paperwidth);
|
row->fill = Fill(row, paperwidth);
|
||||||
@ -3724,9 +3735,9 @@ void LyXText::Backspace()
|
|||||||
|
|
||||||
lastpos = cursor.par->Last();
|
lastpos = cursor.par->Last();
|
||||||
if (cursor.pos == lastpos) {
|
if (cursor.pos == lastpos) {
|
||||||
SetCurrentFont();
|
|
||||||
if (IsBoundary(cursor.par, cursor.pos) != cursor.boundary)
|
if (IsBoundary(cursor.par, cursor.pos) != cursor.boundary)
|
||||||
SetCursor(cursor.par, cursor.pos, false, !cursor.boundary);
|
SetCursor(cursor.par, cursor.pos, false, !cursor.boundary);
|
||||||
|
SetCurrentFont();
|
||||||
}
|
}
|
||||||
|
|
||||||
// check, wether the last characters font has changed.
|
// check, wether the last characters font has changed.
|
||||||
@ -4666,7 +4677,7 @@ int LyXText::GetColumnNearX(Row * row, int & x, bool & boundary) const
|
|||||||
++vc;
|
++vc;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (vc > row->pos && (tmpx+last_tmpx)/2 > x) {
|
if ((tmpx+last_tmpx)/2 > x) {
|
||||||
tmpx = last_tmpx;
|
tmpx = last_tmpx;
|
||||||
left_side = true;
|
left_side = true;
|
||||||
}
|
}
|
||||||
@ -4677,9 +4688,20 @@ int LyXText::GetColumnNearX(Row * row, int & x, bool & boundary) const
|
|||||||
vc = last+1;
|
vc = last+1;
|
||||||
|
|
||||||
boundary = false;
|
boundary = false;
|
||||||
|
bool lastrow = lyxrc.rtl_support // This is not needed, but gives
|
||||||
|
// some speedup if rtl_support=false
|
||||||
|
&& (!row->next || row->next->par != row->par);
|
||||||
|
bool rtl = (lastrow)
|
||||||
|
? row->par->isRightToLeftPar()
|
||||||
|
: false; // If lastrow is false, we don't need to compute
|
||||||
|
// the value of rtl.
|
||||||
|
|
||||||
if (row->pos > last) // Row is empty?
|
if (row->pos > last) // Row is empty?
|
||||||
c = row->pos;
|
c = row->pos;
|
||||||
|
else if (lastrow &&
|
||||||
|
( ( rtl && left_side && vc == row->pos && x < tmpx - 5) ||
|
||||||
|
(!rtl && !left_side && vc == last + 1 && x > tmpx + 5) ))
|
||||||
|
c = last + 1;
|
||||||
else if (vc == row->pos ||
|
else if (vc == row->pos ||
|
||||||
(row->par->table && vc <= last && row->par->IsNewline(vc-1)) ) {
|
(row->par->table && vc <= last && row->par->IsNewline(vc-1)) ) {
|
||||||
c = vis2log(vc);
|
c = vis2log(vc);
|
||||||
|
33
src/text2.C
33
src/text2.C
@ -3416,6 +3416,13 @@ void LyXText::SetCurrentFont() const
|
|||||||
|
|
||||||
current_font = cursor.par->GetFontSettings(pos);
|
current_font = cursor.par->GetFontSettings(pos);
|
||||||
real_current_font = GetFont(cursor.par, pos);
|
real_current_font = GetFont(cursor.par, pos);
|
||||||
|
|
||||||
|
if (cursor.pos == cursor.par->Last() &&
|
||||||
|
IsBoundary(cursor.par, cursor.pos) && !cursor.boundary) {
|
||||||
|
Language const * lang = cursor.par->getParLanguage();
|
||||||
|
current_font.setLanguage(lang);
|
||||||
|
real_current_font.setLanguage(lang);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -3475,10 +3482,7 @@ void LyXText::CursorLeftIntern(bool internal) const
|
|||||||
SetCursor(cursor.par, cursor.pos + 1, true, true);
|
SetCursor(cursor.par, cursor.pos + 1, true, true);
|
||||||
} else if (cursor.par->Previous()) { // steps into the above paragraph.
|
} else if (cursor.par->Previous()) { // steps into the above paragraph.
|
||||||
LyXParagraph * par = cursor.par->Previous();
|
LyXParagraph * par = cursor.par->Previous();
|
||||||
LyXParagraph::size_type pos = par->Last();
|
SetCursor(par, par->Last());
|
||||||
SetCursor(par, pos);
|
|
||||||
if (IsBoundary(par, pos))
|
|
||||||
SetCursor(par, pos, false, true);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3498,17 +3502,16 @@ void LyXText::CursorRight(bool internal) const
|
|||||||
|
|
||||||
void LyXText::CursorRightIntern(bool internal) const
|
void LyXText::CursorRightIntern(bool internal) const
|
||||||
{
|
{
|
||||||
if (cursor.pos < cursor.par->Last()) {
|
if (!internal && cursor.boundary &&
|
||||||
if (!internal && cursor.boundary &&
|
(!cursor.par->table || !cursor.par->IsNewline(cursor.pos)))
|
||||||
(!cursor.par->table || !cursor.par->IsNewline(cursor.pos)))
|
SetCursor(cursor.par, cursor.pos, true, false);
|
||||||
SetCursor(cursor.par, cursor.pos, true, false);
|
else if (cursor.pos < cursor.par->Last()) {
|
||||||
else {
|
SetCursor(cursor.par, cursor.pos + 1, true, false);
|
||||||
SetCursor(cursor.par, cursor.pos + 1, true, false);
|
if (!internal &&
|
||||||
if (!internal && IsBoundary(cursor.par, cursor.pos))
|
IsBoundary(cursor.par, cursor.pos))
|
||||||
SetCursor(cursor.par, cursor.pos, true, true);
|
SetCursor(cursor.par, cursor.pos, true, true);
|
||||||
}
|
} else if (cursor.par->Next())
|
||||||
} else if (cursor.par->Next())
|
SetCursor(cursor.par->Next(), 0);
|
||||||
SetCursor(cursor.par->Next(), 0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user