parse_expr.o parse_func.o parse_node.o parse_oper.o parse_param.o \
       parse_relation.o parse_target.o parse_type.o parse_utilcmd.o scansup.o
 
-FLEXFLAGS = -CF
+FLEXFLAGS = -CF -b -p -p
 
 include $(top_srcdir)/src/backend/common.mk
 
 scan.c: scan.l
 ifdef FLEX
    $(FLEX) $(FLEXFLAGS) -o'$@' $<
+   @if [ `wc -l <lex.backup` -eq 1 ]; then rm lex.backup; else echo "Scanner requires backup, see lex.backup."; exit 1; fi
 else
    @$(missing) flex $< $@
 endif
 
 # gram.c, gram.h, and scan.c are in the distribution tarball, so they
 # are not cleaned here.
+clean distclean maintainer-clean:
+   rm -f lex.backup
 
  * for handling float numbers and continued string literals.  If you change
  * the lexical rules, verify that you haven't broken the no-backtrack
  * property by running flex with the "-b" option and checking that the
- * resulting "lex.backup" file says that no backing up is needed.
+ * resulting "lex.backup" file says that no backing up is needed.  (As of
+ * Postgres 9.2, this check is made automatically by the Makefile.)
  *
  *
  * Portions Copyright (c) 1996-2011, PostgreSQL Global Development Group
 
    sql_help.o \
    $(WIN32RES)
 
-FLEXFLAGS = -Cfe
+FLEXFLAGS = -Cfe -b -p -p
 
 
 all: psql
 psqlscan.c: psqlscan.l
 ifdef FLEX
    $(FLEX) $(FLEXFLAGS) -o'$@' $<
+   @if [ `wc -l <lex.backup` -eq 1 ]; then rm lex.backup; else echo "Scanner requires backup, see lex.backup."; exit 1; fi
 else
    @$(missing) flex $< $@
 endif
 
 # psqlscan.c is in the distribution tarball, so is not cleaned here
 clean distclean:
-   rm -f psql$(X) $(OBJS) dumputils.c keywords.c kwlookup.c
+   rm -f psql$(X) $(OBJS) dumputils.c keywords.c kwlookup.c lex.backup
 
 maintainer-clean: distclean
    rm -f sql_help.h sql_help.c psqlscan.c