Noweb is a Literate Programming (minor) mode written for Emacs by Norman Ramsey (http://www.cs.tufts.edu/~nr/noweb/) - I used it about 7 years ago and only recently (8 days ago :-)) revisited the latest version. The major appeal of noweb over other literate programming modes (if they exist) is that it is language independent i.e. you can do literate programming in Python, C/C++, Pascal or whatever strikes your fancy. This is what first attracted me to it and still brings me back to it. I haven't looked into this, but I believe what is happening is that noweb mode allows Emacs to switch between major modes as point moves through the buffer (Latex and whatever the major mode is for the target code). Which is a great idea and makes things very convenient for the programmer as we all depend on major mode features for almost everything we do, so latex features are required for the documentation portions and C/C++ features for the code portion (in wew's case). Unfortunately the major mode (C/C++ in this case) scans the ENTIRE file when making syntax highlights etc. Similarly, Latex mode (when it is in force) scans the entire buffer and makes its syntax highlights. This is where the mix-up is happening. What is really desired is that whatever process is used for the scanning, that the major mode be "switched" as the region changes between Latex and whatever code mode is being used and each applied to the appropriate region ONLY i.e. as the scanning process passes through a section that is Latex it performs Latex syntax highlighting and as it passes through the region that is code that it performs the appropriate code. I have never looked at what process is involved in syntax highlighting a buffer but the only true fix to this problem is to have the scanning process match the major mode highlighting with the appropriate region as the scan proceeds i.e. as it is travelling through a latex region then use latex highlighting and as it is travelling through a code region use whatever that major mode highlighting needs. Anything else is probably just a waste of time as it will never be "perfect" and will only lead to frustration. So my suggestion is to look into how the scanning process works and try and isolate the appropriate buffer regions to the appropriate major mode. Hope this makes sense :-) Peter On Wed, Aug 19, 2009 at 6:40 AM, wewwew wrote: > On Aug 18, 12:35 pm, Alan Mackenzie wrote: > > Hi, > > > > On Tue, Aug 18, 2009 at 08:21:01AM -0700, wewwew wrote: > > > Hi, > > > How can I disable multi-line string literals in c-mode and c++-mode, > > > and treat the end of line as the end of string literal? > > > > This is not simple. CC Mode uses the "syntax mechanism" of Emacs (See > > the chapter "Syntax Tables" in the Elisp manual if you're interested), > > which does things like matching up parentheses, recognising comments and, > > in particular, recognising strings. > > > > To modify this string recognition, you'd have to identify the EOLs which > > act as string terminators and individually mark them as such (by giving > > them a "string" syntax-table property). > > > > You would need to modify CC Mode (by adding this option) to achieve this. > > It is not clear to me how easy to do that. Can I disable all string > literals? > > > > > > I am programming using noweb, where LaTeX and C++ sources are mixed > > > together. When editing the code part, the buffer uses c++-mode, but > > > any single quote in the text is treated as start or end of string > > > literal, so many of my code chunks are rendered as string literals. I > > > would like to disable this multi-line string literals in c++-mode. > > > > I don't know noweb. Is there any easy and reliable way to recognise the > > LaTeX bits within the source file? If so, maybe the mechanism used to > > neutralize lines like > > > > #define QUOTE " > > > > could be adapted. The above, fully legitimate, line used to cause the > > following lines to be fontified as strings. > > I could also put a LaTeX comment in the text to do this: > > %' > > However, I would prefer not to use such hacks, because whenever I add/ > remove quote in LaTeX text, the whole font colors of C/C++ code is > messed up again. > > All C/C++ code are within such blocks: > > << some text >>= > // C/C++ code here > @ > > Where the "<<" and "@" always start on the first column. Ideally, C/C+ > +-mode should only fontify chunks within the "<<" and "@". Is that > possible? > > Thanks! > > -Wenguang > > > > > > Appreciate any help. > > > -Wenguang > > > > -- > > Alan Mackenzie (Nuremberg, Germany). > >