Поскольку мы не можем найти версию в Интернете, давайте начнем ее здесь. Большинство портов для 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 */
Не нужно прятать.
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
), локальные изменения не будут перезаписаны после несохранения.
Попробуйте:
git stash
git checkout -b new-branch
git stash apply