Git: Создать ветку из неустановленных / незафиксированных изменений на master

Поскольку мы не можем найти версию в Интернете, давайте начнем ее здесь. Большинство портов для Windows, вероятно, нуждаются только в подмножестве полного файла Unix. Вот отправная точка. При необходимости добавьте определения.

#ifndef _UNISTD_H
#define _UNISTD_H    1

/* This is intended as a drop-in replacement for unistd.h on Windows.
 * Please add functionality as neeeded.
 * https://stackoverflow.com/a/826027/1202830
 */

#include <stdlib.h>
#include <io.h>
#include <getopt.h> /* getopt at: https://gist.github.com/ashelly/7776712 */
#include <process.h> /* for getpid() and the exec..() family */
#include <direct.h> /* for _getcwd() and _chdir() */

#define srandom srand
#define random rand

/* Values for the second argument to access.
   These may be OR'd together.  */
#define R_OK    4       /* Test for read permission.  */
#define W_OK    2       /* Test for write permission.  */
//#define   X_OK    1       /* execute permission - unsupported in windows*/
#define F_OK    0       /* Test for existence.  */

#define access _access
#define dup2 _dup2
#define execve _execve
#define ftruncate _chsize
#define unlink _unlink
#define fileno _fileno
#define getcwd _getcwd
#define chdir _chdir
#define isatty _isatty
#define lseek _lseek
/* read, write, and close are NOT being #defined here, because while there are file handle specific versions for Windows, they probably don't work for sockets. You need to look at your app and consider whether to call e.g. closesocket(). */

#ifdef _WIN64
#define ssize_t __int64
#else
#define ssize_t long
#endif

#define STDIN_FILENO 0
#define STDOUT_FILENO 1
#define STDERR_FILENO 2
/* should be in some equivalent to <sys/types.h> */
typedef __int8            int8_t;
typedef __int16           int16_t; 
typedef __int32           int32_t;
typedef __int64           int64_t;
typedef unsigned __int8   uint8_t;
typedef unsigned __int16  uint16_t;
typedef unsigned __int32  uint32_t;
typedef unsigned __int64  uint64_t;

#endif /* unistd.h  */
907
задан Cœur 9 October 2017 в 05:04
поделиться

2 ответа

Не нужно прятать.

git checkout -b new_branch_name

не касается ваших локальных изменений. Он просто создает ветку из текущего HEAD и устанавливает там HEAD. Так что, я думаю, это то, что вам нужно.

--- Отредактируйте, чтобы объяснить результат работы мастера проверки ---

Вы запутались, потому что мастер проверки не отменяет ваши изменения?

Поскольку изменения являются только локальными, git делает это не хочу, чтобы вы слишком легко их теряли. При изменении ветки git не перезаписывает ваши локальные изменения. Результат вашего мастера оформления заказа :

M   testing

, что означает, что ваши рабочие файлы не чистые. git изменил ГОЛОВУ, но не перезаписал ваши локальные файлы. Вот почему ваш последний статус по-прежнему показывает ваши локальные изменения, хотя вы находитесь на главном сервере .

Если вы действительно хотите отменить локальные изменения, вы должны принудительно выполнить извлечение с помощью -f .

git checkout master -f

Поскольку ваши изменения никогда не фиксировались, вы их потеряете.

Попробуйте вернуться в свою ветку, зафиксируйте изменения, затем снова проверьте мастер.

git checkout new_branch
git commit -a -m"edited"
git checkout master
git status

Вы должны получить сообщение M после первой проверки, но больше не после главной проверки , а git status не должны показывать измененных файлов.

--- Отредактируйте, чтобы устранить путаницу с рабочим каталогом (локальными файлами) ---

В ответ на ваш первый комментарий, локальные изменения просто ... ну, локальные. Git не сохраняет их автоматически, вы должны указать ему сохранить их на будущее. Если вы вносите изменения и не фиксируете или не храните их явно, git не будет их версировать.Если вы измените HEAD ( checkout master ), локальные изменения не будут перезаписаны после несохранения.

1149
ответ дан 19 December 2019 в 20:21
поделиться

Попробуйте:

git stash
git checkout -b new-branch
git stash apply
57
ответ дан 19 December 2019 в 20:21
поделиться
Другие вопросы по тегам:

Похожие вопросы: