1. 04 Feb, 2005 4 commits
    • unknown's avatar
      Proposal to fix this problem: when using libmysqlclient, you must call... · e5e1758b
      unknown authored
      Proposal to fix this problem: when using libmysqlclient, you must call mysql_server_end() to nicely free memory at the end of your program; it however
      sounds weird to call a function named *SERVER_end* when you're the CLIENT (you're not ending the server, you're ending your ability to talk to servers).
      So here I add two defines which should be more generic names. This was longly discussed with Konstantin, Serg, Brian. The problem started from
      a post on valgrind-users list: http://sourceforge.net/mailarchive/forum.php?thread_id=5778035&forum_id=32038 ; our manual mentions these functions
      only for libmysqld API so needs some fixing, and then we can close BUG#8099 and BUG#6149.
      
      
      include/mysql.h:
        Creating synonyms (defines): mysql_library_init for mysql_server_init, mysql_library_end for mysql_server_end;
        these new names are more generic, so suitable when using libmysqlclient as well as libmysqld.c
      e5e1758b
    • unknown's avatar
      Merge mysql.com:/Users/kent/mysql/bk/mysql-4.1-perl · d407bf4a
      unknown authored
      into mysql.com:/Users/kent/mysql/bk/mysql-5.0-compile
      
      d407bf4a
    • unknown's avatar
      Merge · 153c2113
      unknown authored
      
      BitKeeper/etc/logging_ok:
        auto-union
      sql/item_func.cc:
        Auto merged
      ndb/src/common/util/NdbSqlUtil.cpp:
        merge
      153c2113
    • unknown's avatar
      Merge kboortz@bk-internal.mysql.com:/home/bk/mysql-4.1 · a7e02476
      unknown authored
      into mysql.com:/Users/kent/mysql/bk/mysql-4.1-perl
      
      a7e02476
  2. 03 Feb, 2005 29 commits
    • unknown's avatar
      Merge bk-internal.mysql.com:/home/bk/mysql-4.1 · 68d2c5d5
      unknown authored
      into pcgem.rdg.cyberkinetica.com:/var/db/bk/work-acurtis/bug8057
      
      68d2c5d5
    • unknown's avatar
      Merge bk-internal.mysql.com:/home/bk/mysql-5.0 · 8405ff01
      unknown authored
      into pcgem.rdg.cyberkinetica.com:/var/db/bk/work-acurtis/bug6726
      
      8405ff01
    • unknown's avatar
      Bug#6726 - failure to parse NOT BETWEEN · 18c21eb6
      unknown authored
        Fix and test for parse bug
      
      
      mysql-test/r/func_test.result:
        Bug#6726
          Test for parse bug
      mysql-test/t/func_test.test:
        Bug#6726
          Test for parse bug
      sql/sql_yacc.yy:
        Bug#6726
          Parser was confused by NOT in lookahead
      18c21eb6
    • unknown's avatar
      ndb - sol9x86: cc -xO3: fix optimizer error. · b34618be
      unknown authored
      
      ndb/src/common/util/NdbSqlUtil.cpp:
        sol9x86: cc -xO3: fix optimizer error.
        Note: same expression remains in Field_newdate::val_int().
      b34618be
    • unknown's avatar
      Merge bk-internal.mysql.com:/home/bk/mysql-4.1 · 3ea05a5f
      unknown authored
      into pcgem.rdg.cyberkinetica.com:/var/db/bk/work-acurtis/bug8057
      
      
      sql/item_func.cc:
        Auto merged
      3ea05a5f
    • unknown's avatar
      Bug#8057 · db8ff6b2
      unknown authored
        Fix crash with LAST_INSERT_ID() in UPDATE,
        Tests included,
      
      
      mysql-test/r/update.result:
        Bug#8057
          Test for bug
      mysql-test/t/update.test:
        Bug#8057
          Test for bug
      sql/item_func.cc:
        Bug#8057
          Don't create new Item in val_int()
      db8ff6b2
    • unknown's avatar
      Merge kboortz@bk-internal.mysql.com:/home/bk/mysql-4.1 · 78191155
      unknown authored
      into mysql.com:/Users/kent/mysql/bk/mysql-4.1-perl
      
      78191155
    • unknown's avatar
      mtr_cases.pl: · 97e031d1
      unknown authored
        new file
      
      97e031d1
    • unknown's avatar
      Merge gbichot@bk-internal.mysql.com:/home/bk/mysql-5.0 · e8f8072a
      unknown authored
      into mysql.com:/home/mysql_src/mysql-5.0-clean
      
      e8f8072a
    • unknown's avatar
      result update after merge · 447e48ef
      unknown authored
      
      mysql-test/r/rpl_change_master.result:
        result update after WL#1062 and merge
      mysql-test/r/rpl_until.result:
        result update after WL#1062 and merge
      447e48ef
    • unknown's avatar
      Merge mronstrom@bk-internal.mysql.com:/home/bk/mysql-5.0 · 04188586
      unknown authored
      into orca.ndb.mysql.com:/export/home/mikael/mysql-5.0
      
      
      BitKeeper/etc/logging_ok:
        Logging to logging@openlogging.org accepted
      04188586
    • unknown's avatar
      Merge mysql.com:/Users/kent/mysql/bk/mysql-4.1-perl · 38998db6
      unknown authored
      into mysql.com:/Users/kent/mysql/bk/mysql-5.0-compile
      
      38998db6
    • unknown's avatar
      Merge mronstrom@bk-internal.mysql.com:/home/bk/mysql-4.1 · 9a086e8a
      unknown authored
      into orca.ndb.mysql.com:/export/home/mikael/mysql-4.1
      
      
      BitKeeper/etc/logging_ok:
        Logging to logging@openlogging.org accepted
      9a086e8a
    • unknown's avatar
      mysql-test-run.pl: · 6f2b1823
      unknown authored
        Let --start-and-exit actually start a server
        Added that test case names can be specified on the comman line
        Added embedded server support
        Added environment variables UMASK, UMASK_DIR
        Added missing MASTER_MYSOCK1, MASTER_MYPORT1, USE_RUNNING_SERVER
        Added missing CHARSETSDIR, MYSQL_FIX_SYSTEM_TABLES, MYSQL_CLIENT_TEST
        Pass on return value from sleep_until_file_created(), to fail test
        Fail test if early termination of mysqld servers
        Create intial databases for the second master, and two additional slaves
      mtr_process.pl:
        Find out if port is still in use, using simple TCP connect
        Use non blocking waitpid() to catch terminations early
        Make a special case spawning the 'mysqltest' application
        Redo the fork() if it returns EAGAIN
        Make sure to record if master or slave terminated
        Improved debugging output
        Improved code that remove PID files to avoid race
        Abort if we can't stop all mysqld servers using our ports
        Many improvements in killing mysqld servers
        Let sleep_until_file_created() catch if server died early
      mtr_report.pl:
        Added option to disable test cases using <testcase>.disabled file
        If --timer, only try to open file with time data if it exists
      mtr_io.pl:
        Remove starting/ending space reading server options from file
      
      
      mysql-test/lib/mtr_io.pl:
        Remove starting/ending space reading server options from file
      mysql-test/lib/mtr_report.pl:
        Added option to disable test cases using <testcase>.disabled file
        If --timer, only try to open file with time data if it exists
      mysql-test/lib/mtr_process.pl:
        Find out if port is still in use, using simple TCP connect
        Use non blocking waitpid() to catch terminations early
        Make a special case spawning the 'mysqltest' application
        Redo the fork() if it returns EAGAIN
        Make sure to record if master or slave terminated
        Improved debugging output
        Improved code that remove PID files to avoid race
        Abort if we can't stop all mysqld servers using our ports
        Many improvements in killing mysqld servers
        Let sleep_until_file_created() catch if server died early
      mysql-test/mysql-test-run.pl:
        Let --start-and-exit actually start a server
        Added that test case names can be specified on the comman line
        Added embedded server support
        Added environment variables UMASK, UMASK_DIR
        Added missing MASTER_MYSOCK1, MASTER_MYPORT1, USE_RUNNING_SERVER
        Added missing CHARSETSDIR, MYSQL_FIX_SYSTEM_TABLES, MYSQL_CLIENT_TEST
        Pass on return value from sleep_until_file_created(), to fail test
        Fail test if early termination of mysqld servers
        Create intial databases for the second master, and two additional slaves
      6f2b1823
    • unknown's avatar
      Merge gbichot@bk-internal.mysql.com:/home/bk/mysql-5.0 · d22a8ea8
      unknown authored
      into mysql.com:/home/mysql_src/mysql-5.0-clean
      
      
      sql/mysql_priv.h:
        Auto merged
      sql/set_var.cc:
        Auto merged
      d22a8ea8
    • unknown's avatar
      Merge mronstrom@bk-internal.mysql.com:/home/bk/mysql-4.1 · ca24158d
      unknown authored
      into mysql.com:/Users/mikron/mysql-4.1
      
      ca24158d
    • unknown's avatar
      Merge mysql.com:/Users/mikron/mysql-4.1 · 30dba7e5
      unknown authored
      into mysql.com:/Users/mikron/mysql-5.0
      
      
      ndb/src/kernel/vm/FastScheduler.cpp:
        Auto merged
      30dba7e5
    • unknown's avatar
      Merge mysql.com:/home/mysqldev/tulin/mysql-4.1 · 2cc9b8c2
      unknown authored
      into mysql.com:/home/mysqldev/tulin/mysql-5.0
      
      2cc9b8c2
    • unknown's avatar
      made an .sh file of ndb-config-2-node.ini instead · 43125cb2
      unknown authored
      
      support-files/ndb-config-2-node.ini.sh:
        Rename: support-files/ndb-config-2-node.ini -> support-files/ndb-config-2-node.ini.sh
      43125cb2
    • unknown's avatar
      Merge mysql.com:/home/mysqldev/tulin/mysql-4.1 · 410f6cb4
      unknown authored
      into mysql.com:/home/mysqldev/tulin/mysql-5.0
      
      
      support-files/mysql.spec.sh:
        Auto merged
      410f6cb4
    • unknown's avatar
      ndbcluster rpms · d954574f
      unknown authored
      d954574f
    • unknown's avatar
      corrected automerge error · e601876f
      unknown authored
      
      configure.in:
        Auto merged
      include/my_global.h:
        Auto merged
      ndb/src/common/transporter/TransporterRegistry.cpp:
        Auto merged
      ndb/src/mgmclient/CommandInterpreter.cpp:
        Auto merged
      ndb/src/mgmsrv/ConfigInfo.cpp:
        Auto merged
      ndb/src/mgmsrv/MgmtSrvr.cpp:
        Auto merged
      BitKeeper/deleted/.del-acinclude.m4~f4ab416bac5003:
        Auto merged
      ndb/src/ndbapi/ClusterMgr.cpp:
        Auto merged
      ndb/src/ndbapi/TransporterFacade.cpp:
        Auto merged
      ndb/src/ndbapi/ndb_cluster_connection.cpp:
        Auto merged
      ndb/test/ndbapi/flexAsynch.cpp:
        Auto merged
      ndb/test/ndbapi/flexBench.cpp:
        Auto merged
      ndb/test/ndbapi/flexHammer.cpp:
        Auto merged
      ndb/test/ndbapi/flexTT.cpp:
        Auto merged
      ndb/test/ndbapi/flex_bench_mysql.cpp:
        Auto merged
      ndb/test/src/NDBT_Test.cpp:
        corrected automerge error
      e601876f
    • unknown's avatar
      After merge fixes · 53925833
      unknown authored
      
      sql/item.cc:
        After merge fixes (bug during merge)
      sql/sql_show.cc:
        Ensure that lex->all_select_list is properly reset on function end
        (Caused crashes after merge)
      53925833
    • unknown's avatar
      Merge gbichot@bk-internal.mysql.com:/home/bk/mysql-5.0 · cf1ce798
      unknown authored
      into mysql.com:/home/mysql_src/mysql-5.0-clean
      
      
      mysql-test/mysql-test-run.sh:
        Auto merged
      sql/mysql_priv.h:
        Auto merged
      sql/set_var.cc:
        Auto merged
      sql/set_var.h:
        Auto merged
      cf1ce798
    • unknown's avatar
      WL#1062 "log charset info into all Query_log_event": · 417c215d
      unknown authored
      we store 7 bytes (1 + 2*3) in every Query_log_event.
      In the future if users want binlog optimized for small size and less safe,
      we could add --binlog-no-charset (and binlog-no-sql-mode etc): charset info
      is something by design optional (even if for now we don't offer possibility to disable it):
      it's not a binlog format change.
      We try to reduce the number of get_charset() calls in the slave SQL thread to a minimum
      by caching the charset read from the previous event (which will often be equal to the one of the current event).
      We don't use SET ONE_SHOT for charset-aware repl (we still do for timezones, will be fixed later).
      No more errors if one changes the global value of charset vars on master or slave
      (as we log charset info in all Query_log_event).
      Not fixing Load_log_event as it will be rewritten soon by Dmitri.
      Testing how mysqlbinlog behaves in rpl_charset.test.
      mysqlbinlog needs to know where charset file is (to be able to convert a charset number found
      in binlog (e.g. in User_var_log_event) to a charset name); mysql-test-run needs to pass
      the correct value for this option to mysqlbinlog.
      Many result udpates (adding charset info into every event shifts log_pos in SHOW BINLOG EVENTS).
      Roughly the same job is to be done for timezones :)
      
      
      client/mysqlbinlog.cc:
        mysqlbinlog needs charsets knowledge, to be able to convert a charset
        number found in binlog to a charset name (to be able to print things
        like this:
        SET @`a`:=_cp850 0x4DFC6C6C6572 COLLATE `cp850_general_ci`;
      mysql-test/mysql-test-run.sh:
        tell mysqlbinlog about charsets dir
      mysql-test/r/ctype_ucs.result:
        different binlogging of charsets results in shifted log_pos and
        one added SET @@CHARACTER_SET... per mysqlbinlog run.
      mysql-test/r/drop_temp_table.result:
        different binlogging of charsets results in shifted log_pos and
        one added SET @@CHARACTER_SET... per mysqlbinlog run.
      mysql-test/r/insert_select.result:
        different binlogging of charsets results in shifted log_pos and
        one added SET @@CHARACTER_SET... per mysqlbinlog run.
      mysql-test/r/mix_innodb_myisam_binlog.result:
        different binlogging of charsets results in shifted log_pos and
        one added SET @@CHARACTER_SET... per mysqlbinlog run.
      mysql-test/r/mysqlbinlog.result:
        different binlogging of charsets results in shifted log_pos and
        one added SET @@CHARACTER_SET... per mysqlbinlog run.
      mysql-test/r/mysqlbinlog2.result:
        different binlogging of charsets results in shifted log_pos and
        one added SET @@CHARACTER_SET... per mysqlbinlog run.
        The log_pos shift is why the SET INSERT_ID=4 event changes position in the result.
      mysql-test/r/rpl_charset.result:
        Running mysqlbinlog to check how it behaves on charset stuff.
        SET ONE_SHOT is now gone.
        Repl of LOAD DATA INFILE is not yet charset-aware (will soon be, when WL#874 is pushed)
        and, anyway result has a dependency on the temp filename (SQL-LOAD-*-[0-9] which is not constant).
        No more errors if one changes global character sets.
      mysql-test/r/rpl_error_ignored_table.result:
        different binlogging of charsets results in shifted log_pos and
        one added SET @@CHARACTER_SET... per mysqlbinlog run.
      mysql-test/r/rpl_flush_log_loop.result:
        different binlogging of charsets results in shifted log_pos and
        one added SET @@CHARACTER_SET... per mysqlbinlog run.
      mysql-test/r/rpl_flush_tables.result:
        different binlogging of charsets results in shifted log_pos and
        one added SET @@CHARACTER_SET... per mysqlbinlog run.
      mysql-test/r/rpl_loaddata.result:
        different binlogging of charsets results in shifted log_pos and
        one added SET @@CHARACTER_SET... per mysqlbinlog run.
      mysql-test/r/rpl_loaddata_rule_m.result:
        different binlogging of charsets results in shifted log_pos and
        one added SET @@CHARACTER_SET... per mysqlbinlog run.
      mysql-test/r/rpl_log.result:
        different binlogging of charsets results in shifted log_pos and
        one added SET @@CHARACTER_SET... per mysqlbinlog run.
      mysql-test/r/rpl_max_relay_size.result:
        different binlogging of charsets results in shifted log_pos and
        one added SET @@CHARACTER_SET... per mysqlbinlog run.
      mysql-test/r/rpl_relayrotate.result:
        different binlogging of charsets results in shifted log_pos and
        one added SET @@CHARACTER_SET... per mysqlbinlog run.
      mysql-test/r/rpl_replicate_do.result:
        different binlogging of charsets results in shifted log_pos and
        one added SET @@CHARACTER_SET... per mysqlbinlog run.
      mysql-test/r/rpl_rotate_logs.result:
        different binlogging of charsets results in shifted log_pos and
        one added SET @@CHARACTER_SET... per mysqlbinlog run.
      mysql-test/r/rpl_temporary.result:
        different binlogging of charsets results in shifted log_pos and
        one added SET @@CHARACTER_SET... per mysqlbinlog run.
      mysql-test/r/rpl_timezone.result:
        different binlogging of charsets results in shifted log_pos and
        one added SET @@CHARACTER_SET... per mysqlbinlog run.
      mysql-test/r/rpl_user_variables.result:
        different binlogging of charsets results in shifted log_pos and
        one added SET @@CHARACTER_SET... per mysqlbinlog run.
      mysql-test/r/user_var.result:
        different binlogging of charsets results in shifted log_pos and
        one added SET @@CHARACTER_SET... per mysqlbinlog run.
      mysql-test/t/rpl_charset.test:
        Running mysqlbinlog to check how it behaves on charset stuff (so, need fixed timestamp).
        SET ONE_SHOT is not printed to binlog anymore, so no need to test if ::exec_event() works ok.
        Repl of LOAD DATA INFILE is not yet charset-aware (will soon be, when WL#874 is pushed)
        and, anyway result has a dependency on the temp filename (SQL-LOAD-*-[0-9] which is not constant).
        No more errors if one changes global character sets.
      mysql-test/t/rpl_user_variables.test:
        different binlogging of charsets results in shifted log_pos and
        one added SET @@CHARACTER_SET... per mysqlbinlog run.
      sql/log.cc:
        No more SET ONE_SHOT for charsets (remains for TZ until solved with Dmitri).
      sql/log_event.cc:
        We now log charset info in each Query_log_event in binlog. It's 2*3 = 6 bytes:
        session character_set_client, session collation_connection, session collation_server.
        Now we would need only one byte per variable, but Bar said 2 is safer for the future.
        When slave or mysqlbinlog reads that info, it needs to get_charset() on these numbers (so, 3 get_charset() calls),
        as most of the time the 6-byte charset info will be equal to the previous event's,
        we cache the previous event's charset and if equal, no need to get_charset().
        As "flags2", SQL_MODE, catalog, autoinc variables, charset info is not a permanent addition:
        in the future we can add options to the master to not log any of these, old 5.0 should be able
        to parse these.
        A little bit of cleanup on autoinc stuff in replication.
        Fixing a bug in Start_log_event_v3::exec_event() where we used rli->relay_log.description_event_for_exec->binlog_version
        while we should use binlog_version (if it's a 3.23 master, that's all that counts; not the fact that the relay log is
        in 5.0 format).
      sql/log_event.h:
        binlogging of charset info in each Query_log_event.
      sql/mysql_priv.h:
        comment
      sql/set_var.cc:
        checks to refuse change of global charset variables are removed: they were needed for 4.1->4.1
        but not for 5.0.3->5.0.3.
        Yes this opens a breach if one does 4.1->5.0.3, where the checks would still be needed. But these checks would need
        reading relay_log.description_event_for_queue, which is currently an object used in many places by the I/O
        thread and only it. So, currently we don't take mutexes for this object, and if we read the object in set_var.cc
        (client thread) we need to add mutexes everywhere, but the replication code is already too broken with mutexes
        now (no consistent use of mutexes); mutex usage in replication should be fixed but preferrably during/after
        multimaster coding as it's going to shuffle mutexes already.
      sql/set_var.h:
        Since we don't forbid global change of charset vars for replication/binlogging,
        don't need specific ::check() methods anymore
      sql/slave.cc:
        Some little debug info which has nothing to do with charsets.
        Disabling master's charset check when slave I/O thread connects.
        Functions for charset caching/invalidating in the slave SQL thread.
      sql/slave.h:
        Cached charset in the slave SQL thread.
      417c215d
    • unknown's avatar
      Merge bk-internal.mysql.com:/home/bk/mysql-5.0 · 1ffdcf26
      unknown authored
      into mysql.com:/home/my/mysql-5.0
      
      
      BitKeeper/etc/logging_ok:
        auto-union
      configure.in:
        Auto merged
      scripts/mysql_install_db.sh:
        Auto merged
      sql/examples/ha_archive.cc:
        Auto merged
      sql/ha_innodb.cc:
        Auto merged
      1ffdcf26
    • unknown's avatar
      4.1 -> 5.0 merge · 3ffe147c
      unknown authored
      
      BitKeeper/etc/logging_ok:
        auto-union
      Build-tools/Do-compile:
        Auto merged
      client/mysqladmin.cc:
        Auto merged
      client/mysqldump.c:
        Auto merged
      configure.in:
        Auto merged
      extra/perror.c:
        Auto merged
      innobase/buf/buf0rea.c:
        Auto merged
      innobase/fil/fil0fil.c:
        Auto merged
      innobase/include/rem0rec.ic:
        Auto merged
      innobase/include/univ.i:
        Auto merged
      innobase/os/os0file.c:
        Auto merged
      innobase/ut/ut0ut.c:
        Auto merged
      mysql-test/r/derived.result:
        Auto merged
      mysql-test/r/func_str.result:
        Simple merge
      mysql-test/r/subselect.result:
        Automatic merge
      mysql-test/t/derived.test:
        Automatic merge
      mysql-test/t/func_str.test:
        Simple merge
      mysql-test/t/subselect.test:
        Automatic merge
      mysys/my_handler.c:
        Automatic merge
      ndb/src/kernel/blocks/backup/Backup.cpp:
        Automatic merge
      scripts/make_binary_distribution.sh:
        Automatic merge
      scripts/mysql_install_db.sh:
        Automatic merge
      sql/examples/ha_archive.cc:
        Simple merge
      sql/ha_innodb.cc:
        Automatic merge
      sql/item.cc:
        Merge
      sql/item_cmpfunc.h:
        Automatic merge
      sql/item_func.cc:
        Simple merge
      sql/item_func.h:
        Automatic merge
      sql/item_strfunc.cc:
        Automatic merge
      sql/item_strfunc.h:
        Automatic merge
      sql/item_subselect.cc:
        Automatic merge
      sql/mysqld.cc:
        Automatic merge
      sql/set_var.cc:
        Automatic merge
      sql/sql_base.cc:
        Automatic merge
      sql/sql_class.cc:
        Automatic merge
      sql/sql_class.h:
        Automatic merge
      sql/sql_lex.cc:
        Automatic merge
      sql/sql_lex.h:
        Automatic merge
      sql/sql_parse.cc:
        Automatic merge
      sql/sql_select.cc:
        Automatic merge
      sql/sql_table.cc:
        Automatic merge
      sql/sql_update.cc:
        Simple merge
      strings/ctype-big5.c:
        Automatic merge
      strings/ctype-bin.c:
        Automatic merge
      strings/ctype-gbk.c:
        Automatic merge
      strings/ctype-latin1.c:
        Automatic merge
      strings/ctype-mb.c:
        Automatic merge
      strings/ctype-simple.c:
        Automatic merge
      strings/ctype-sjis.c:
        Automatic merge
      strings/ctype-tis620.c:
        Automatic merge
      strings/ctype-ucs2.c:
        Automatic merge
      strings/ctype-utf8.c:
        Automatic merge
      vio/viosocket.c:
        Automatic merge
      vio/viossl.c:
        Automatic merge
      3ffe147c
    • unknown's avatar
      Revert error I did. · ef6442f2
      unknown authored
      
      BitKeeper/etc/ignore:
        Revert the ignore change I did.
      ef6442f2
    • unknown's avatar
      Fixed a bug: deadlock without any locking, simple select and update (Bug #7975). · 7f0df38f
      unknown authored
      
      innobase/row/row0ins.c:
        If the SQL-query will update or replace duplicate key row we take X-lcok
        for duplicate row.
      sql/ha_innodb.cc:
        INSERT ON DUPLICATE KEY UPDATE will also update duplicate key and we can
        take X-lock in this case for duplicate key records.
      BitKeeper/etc/ignore:
        Added innobase/row/row0index.c to the ignore list
      7f0df38f
  3. 02 Feb, 2005 7 commits