VSS操作详解:服务器与客户端基本操作

需积分: 0 4 下载量 177 浏览量 更新于2024-08-16 收藏 617KB PPT 举报
"这篇文档是关于Visual SourceSafe (VSS) 的详细教程,涵盖了服务器端和客户端的基本操作,包括打开数据库、创建项目、添加文件、删除、重命名、设置工作文件夹、打标签、移动等操作。教程还涉及到权限管理、用户管理以及SCM流程中的各种操作。" 在VSS操作指南中,服务器端的操作主要包括: 1. **打开SourceSafe数据库**:管理员可以通过浏览选择已经创建的数据库来连接到VSS系统。 2. **用户管理**:包括添加用户、删除用户、编辑用户和更改密码。添加用户用于增加新用户,删除用户则从系统中移除他们,编辑用户用于修改用户信息,而更改密码则允许管理员修改特定用户的访问密码。 3. **权限设置**:管理员可以通过"Rights by Project…"分配每个项目权限,添加或删除用户的权限。"Rights Assignments for User…"允许管理员为选定用户指定权限,编辑他们在项目列表中的权限。"Copy User Rights…"功能可以将一个用户的权限复制给另一个用户。 4. **数据库维护**:如锁定数据库以防止用户更改文件,清理临时目录以优化存储空间,以及创建新的数据库。 5. **选项设置**:包括多人同时检出文件的允许、用户自动登录的设置、默认数据库名称、文件类型扩展符、远程文件活动记录等,这些设置影响着VSS的总体行为。 客户端的基本操作主要包括: 1. **Open sourcesafe database**:客户端用户需要连接到VSS服务器上的数据库。 2. **Create project**:创建一个新的项目,组织代码和其他资源。 3. **Add files**:将本地文件添加到VSS版本控制下。 4. **Delete**:从VSS中删除不再需要的文件或项目。 5. **Rename**:重命名项目或文件。 6. **Properties**:查看或修改文件或项目的属性。 7. **Set working folder**:设定工作文件夹,即本地与VSS中项目的对应位置。 8. **Label**:打标签,标记项目或文件的特定版本,便于回溯。 9. **Move**:移动项目或文件到VSS中的不同位置。 SCM流程中的操作可能涉及版本控制的常规步骤,如检出、编辑、提交、冲突解决等,确保团队协作中的代码版本一致性。 这个教程详细介绍了VSS的各种操作,对于初次使用VSS或者需要深入了解VSS管理功能的用户来说非常有用。通过学习,用户不仅可以掌握基本操作,还能了解如何进行权限管理和项目维护,提升软件配置管理效率。

void setupADC() { #define ADCpin GPIO_PORT_P6,GPIO_PIN0 GPIO_setAsPeripheralModuleFunctionOutputPin(ADCpin); // 复位P6.0 ADC12_A_init(ADC12_A_BASE,ADC12_A_SAMPLEHOLDSOURCE_SC, ADC12_A_CLOCKSOURCE_ADC12OSC, ADC12_A_CLOCKDIVIDER_1); //软件触发,内部振荡器MODCLK作为时钟 ADC12_A_enable(ADC12_A_BASE); //启用ADC12_A模块 //设置并启用采样定时器脉冲,这里是使用的软件触发的形式,所以选择失能 ADC12_A_setupSamplingTimer(ADC12_A_BASE,ADC12_A_CYCLEHOLD_16_CYCLES,ADC12_A_CYCLEHOLD_16_CYCLES,ADC12_A_MULTIPLESAMPLESDISABLE); ADC12_A_configureMemoryParam param = {0}; param.memoryBufferControlIndex = ADC12_A_MEMORY_0; //将内存缓冲配置为MEMORY_0 param.inputSourceSelect = ADC12_A_INPUT_A0; //将输入A0映射到内存缓冲区0,因为P6.0引脚对应A0 param.positiveRefVoltageSourceSelect = ADC12_A_VREFPOS_AVCC; //正电压为AVcc param.negativeRefVoltageSourceSelect = ADC12_A_VREFNEG_AVSS; //负电压为AVss param.endOfSequence = ADC12_A_NOTENDOFSEQUENCE; //单通道转换 ADC12_A_configureMemory(ADC12_A_BASE,¶m); // } //----------------------------- r e a d A D C -------------------------------- unsigned long readADC() { //开始从MEMORY_0中进行单通道连续转换 ADC12_A_startConversion(ADC12_A_BASE,ADC12_A_MEMORY_0,ADC12_A_SINGLECHANNEL); while(ADC12_A_isBusy(ADC12_A_BASE) == ADC12_A_BUSY){ // 等待转换完成 } //读取ADC转换之后寄存器的值 long result = ADC12_A_getResults(ADC12_A_BASE, ADC12_A_MEMORY_0); //将其转化为单位为mv的电压值 return (3220 * result) / 4096; // 3320是测量的Vss }

2023-07-17 上传

/* * File: ADC.c * Author: tlfte *AD转换,结果在C口和D口的LED上显示,能进行各种通道选择和参考电压,结果对齐方式选择 * Created on 2018年8月6日, 上午10:07 练习AD结果的计算验证,AD_RESULT=VIN×1023÷VREF,讲解887头文件的作用 */ // PIC16F887 Configuration Bit Settings // 'C' source line config statements // CONFIG1 #pragma config FOSC = XT // Oscillator Selection bits (XT oscillator: Crystal/resonator on RA6/OSC2/CLKOUT and RA7/OSC1/CLKIN) #pragma config WDTE = OFF // Watchdog Timer Enable bit (WDT disabled and can be enabled by SWDTEN bit of the WDTCON register) #pragma config PWRTE = OFF // Power-up Timer Enable bit (PWRT disabled) #pragma config MCLRE = ON // RE3/MCLR pin function select bit (RE3/MCLR pin function is digital input, MCLR internally tied to VDD) #pragma config CP = OFF // Code Protection bit (Program memory code protection is disabled) #pragma config CPD = OFF // Data Code Protection bit (Data memory code protection is disabled) #pragma config BOREN = OFF // Brown Out Reset Selection bits (BOR disabled) #pragma config IESO = OFF // Internal External Switchover bit (Internal/External Switchover mode is disabled) #pragma config FCMEN = OFF // Fail-Safe Clock Monitor Enabled bit (Fail-Safe Clock Monitor is disabled) #pragma config LVP = OFF // Low Voltage Programming Enable bit (RB3 pin has digital I/O, HV on MCLR must be used for programming) // CONFIG2 #pragma config BOR4V = BOR40V // Brown-out Reset Selection bit (Brown-out Reset set to 4.0V) #pragma config WRT = OFF // Flash Program Memory Self Write Enable bits (Write protection off) // #pragma config statements should precede project file includes. // Use project enums instead of #define for ON and OFF. #include <xc.h> #define _XTAL_FREQ 4000000 //指明时钟晶振为4MHz,使delay宏定义可以正常使用 void CSH(void); unsigned int AD_SUB(char k); void main( ) { unsigned int y; CSH(); while(1) { __delay_ms(100); //每隔100毫秒循环一次 y=AD_

2023-05-24 上传

void setupADC() { #define ADCpins {GPIO_PORT_P6, GPIO_PIN0, GPIO_PORT_P6, GPIO_PIN1, GPIO_PORT_P6, GPIO_PIN2, GPIO_PORT_P6, GPIO_PIN3, GPIO_PORT_P6, GPIO_PIN4, GPIO_PORT_P6, GPIO_PIN5, GPIO_PORT_P6, GPIO_PIN6, GPIO_PORT_P6, GPIO_PIN7} GPIO_setAsPeripheralModuleFunctionOutputPin(ADCpins); // 复位P6.0 ADC12_A_init(ADC12_A_BASE,ADC12_A_SAMPLEHOLDSOURCE_SC, ADC12_A_CLOCKSOURCE_ADC12OSC, ADC12_A_CLOCKDIVIDER_1); //软件触发,内部振荡器MODCLK作为时钟 ADC12_A_enable(ADC12_A_BASE); //启用ADC12_A模块 //设置并启用采样定时器脉冲,这里是使用的软件触发的形式,所以选择失能 ADC12_A_setupSamplingTimer(ADC12_A_BASE,ADC12_A_CYCLEHOLD_16_CYCLES,ADC12_A_CYCLEHOLD_16_CYCLES,ADC12_A_MULTIPLESAMPLESDISABLE); ADC12_A_configureMemoryParam params[8] = {0}; for (int i = 0; i < 8; i++) { params[i].memoryBufferControlIndex = (ADC12_A_MEMORY_0 + i); params[i].inputSourceSelect = (ADC12_A_INPUT_A0 + i); params[i].positiveRefVoltageSourceSelect = ADC12_A_VREFPOS_AVCC; params[i].negativeRefVoltageSourceSelect = ADC12_A_VREFNEG_AVSS; params[i].endOfSequence = ADC12_A_NOTENDOFSEQUENCE; ADC12_A_configureMemory(ADC12_A_BASE, &(params[i])); } ADC12_A_configureMemory(ADC12_A_BASE,¶m); // } //----------------------------- r e a d A D C -------------------------------- unsigned long readADC() { unsigned long results[8] = {0}; for (int i = 0; i < 8; i++) { ADC12_A_startConversion(ADC12_A_BASE, (ADC12_A_MEMORY_0 + i), ADC12_A_SINGLECHANNEL); while (ADC12_A_isBusy(ADC12_A_BASE) == ADC12_A_BUSY) { // 等待转换完成 } results[i] = ADC12_A_getResults(ADC12_A_BASE, (ADC12_A_MEMORY_0 + i)); } // 然后可以根据需要对转换结果进行处理或返回 //将其转化为单位为mv的电压值 // return (3220 * result) / 4096; // 3320是测量的Vss }

2023-07-17 上传